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PREFACE 


This  book  has  been  designed  as  a  complete  self-contained  text  for 
learning  programming,  using  the  Z80.  It  can  be  used  by  a  person  who 
has  never  programmed  before,  and  should  also  be  of  value  to  anyone 
using  the  Z80. 

For  the  person  who  has  already  programmed,  this  book  will  teach 
specific  programming  techniques  using  (or  working  around)  the  speci- 
fic characteristics  of  the  Z80.  This  text  covers  the  elementary  to  inter- 
mediate techniques  required  to  start  programming  effectively. 

This  text  aims  at  providing  a  true  level  of  competence  to  the  person 
who  wishes  to  program  using  this  microprocessor.  Naturally,  no  book 
will  effectively  teach  how  to  program,  unless  one  actually  practices. 
However,  it  is  hoped  that  this  book  will  take  the  reader  to  the  point 
where  he  feels  that  he  can  start  programming  by  himself  and  can  solve 
simple  or  even  moderately  complex  problems  using  a  microcomputer. 

This  book  is  based  on  the  author's  experience  in  teaching  more  than 
1000  persons  how  to  program  microcomputers.  As  a  result,  it  is  strongly 
structured.  Chapters  normally  go  from  the  simple  to  the  complex.  For 
readers  who  have  already  learned  elementary  programming,  the  intro- 
ductory chapter  may  be  skipped.  For  others  who  have  never  program- 
med, the  final  sections  of  some  chapters  may  require  a  second  reading. 
The  book  has  been  designed  to  take  the  reader  systematically  through 
all  the  basic  concepts  and  techniques  required  to  build  increasingly 
complex  programs.  It  is,  therefore,  strongly  suggested  that  the  ordering 
of  the  chapters  be  followed.  In  addition,  for  effective  results,  it  is 
important  that  the  reader  attempt  to  solve  as  many  exercises  as  possible. 
The  difficulty  within  the  exercises  has  been  carefully  graduated.  They 
are  designed  to  verify  that  the  material  which  has  been  presented  is 
really  understood.  Without  doing  the  programming  exercises,  it  will 
not  be  possible  to  realize  the  full  value  of  this  book  as  an  educational 
medium.  Several  of  the  exercises  may  require  time,  such  as  the  multi- 
plication exercise.  However,  by  doing  them,  you  will  actually  program 
and  learn  by  doing.  This  is  indispensable. 

For  those  who  have  acquired  a  taste  for  programming  when  reaching 
the  end  of  this  volume,  a  companion  volume  is  planned:  the  Z80  Ap- 
plications Book. 
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Other  books  in  this  series  cover  programming  for  other  popular 
microprocessors. 

For  those  who  wish  to  develop  their  hardware  knowiedge,  it  is  sug- 
gested that  the  reference  books  From  Chips  to  Systems:  an  Introduction 
to  Microprocessors  (ref.  C20IA)  and  Microprocessor  Interfacing 
Techniques  (ref.  C207)  be  consulted. 

The  contents  of  this  book  have  been  checked  carefully  and  are 
believed  to  be  reliable.  However,  inevitably,  some  typographical  or 
other  errors  will  be  found.  The  author  will  be  grateful  for  any  comments 
by  alert  readers  so  that  future  editions  may  benefit  from  their  experience. 
Any  other  suggestions  for  improvements,  such  as  other  programs 
desired,  developed,  or  found  of  value  by  readers,  will  be  appreciated. 
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1 

BASIC  CONCEPTS 


INTRODUCTION 

This  chapter  will  introduce  the  basic  concepts  and  definitions  re- 
lating to  computer  programming.  The  reader  already  familiar  with 
these  concepts  may  want  to  glance  quickly  at  the  contents  of  ttiis 
chapter  and  then  move  on  to  Chapter  2.  It  is  suggested,  however, 
that  even  the  experienced  reader  iooit  at  the  contents  of  this  intro- 
ductory chapter.  Many  significant  concepts  are  presented  here  in- 
cluding, for  example,  two's  complement,  BCD,  and  other  represen- 
tations. Some  of  these  concepts  may  be  new  to  the  reader;  others 
may  improve  the  knowledge  and  skills  of  experienced  programmers. 

WHAT  IS  PROGRAMMING? 

Given  a  problem,  one  must  first  devise  a  solution.  This  solution, 
expressed  as  a  step-by-step  procedure,  is  called  an  algorithm.  An 
algorithm  is  a  step-by-step  specification  of  the  solution  to  a  given 
problem.  It  must  terminate  in  a  finite  number  of  steps.  This 
algorithm  may  be  expressed  in  any  language  or  symbolism.  A  sim- 
ple example  of  an  algorithm  is; 

1—  insert  key  in  the  keyhole 

2 —  turn  key  one  full  turn  to  the  left 

3—  seize  doorknob 

4—  -turn  doorknob  left  and  push  the  door 
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At  this  point,  if  the  algorithm  is  correct  for  the  type  of  lock  in- 
volved, the  door  will  open.  This  four-step  procedure  qualifies  as  an 
algorithm  for  door  opening. 

Once  a  solution  to  a  problem  has  been  expressed  in  the  form  of 
an  algorithm,  the  algorithm  must  be  executed  by  the  computer. 
Unfortunately,  it  is  now  a  well-established  fact  that  computers 
cannot  understand  or  execute  ordinary  spoken  English  (or  any 
other  human  language).  The  reason  lies  in  the  syntactic  ambiguity 
of  all  common  human  languages.  Only  a  well-defined  subset  of 
natural  language  can  be  "understood"  by  the  computer.  This  is 
called  a  programming  language. 

Converting  an  algorithm  into  a  sequence  of  instructions  in  a  pro- 
gramming language  is  called  programming.  To  be  more  specific, 
the  actual  translation  phase  of  the  algorithm  into  the  program- 
ming language  is  called  coding.  Programming  really  refers  not  just 
to  the  coding  but  also  to  the  overall  design  of  the  programs  and 
"data  structures"  which  will  implement  the  algorithm. 

Effective  programming  requires  not  only  understanding  the 
possible  implementation  techniques  for  standard  algorithms,  but 
also  the  skillful  use  of  all  the  computer  hardware  resources,  such  as 
internal  registers,  memory,  and  peripheral  devices,  plus  a  creative 
use  of  appropriate  data  structures.  These  techniques  will  be 
covered  in  the  next  chapters. 

Programming  also  requires  a  strict  documentation  discipline,  so 
that  the  programs  are  understandable  to  others,  as  well  as  to  the 
author.  Documentation  must  be  both  internal  and  external  to  the 
program. 

Internal  program  documentation  refers  to  the  comments  placed 
in  the  body  of  a  program,  which  explain  its  operation. 

External  documentation  refers  to  the  design  documents  which 
are  separate  from  the  program;  written  explanations,  manuals, 
and  flowcharts. 

FLOWCHARTING 

One  intermediate  step  is  almost  always  used  between  the 
algorithm  and  the  program.  It  is  called  a  flowchart.  A  flowchart  is 
simply  a  symbolic  representation  of  the  algorithm  expressed  as  a 
sequence  of  rectangles  and  diamonds  containing  the  steps  of  the 
algorithm.  Rectangles  are  used  for  commands,  or  "executable 
statements."  Diamonds  are  used  for  tests  such  as:  If  information 
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X  is  true,  then  take  action  A,  else  B.  Instead  of  presenting  a  formal 
definition  of  flowcharts  at  this  point,  we  will  introduce  and  discuss 
flowcharts  later  on  in  the  book  when  we  present  programs. 

Flowcharting  is  a  highly  recommended  intermediate  step  be- 
tween the  algorithm  specification  and  the  actual  coding  of  the  solu- 
tion. Remarkably,  it  has  been  observed  that  perhaps  10%  of  the 
programming  population  can  write  a  program  successfully  with- 
out having  to  flowchart.  Unfortunately,  it  has  also  been  observed 
that  9QWo  of  the  population  believes  it  belongs  to  this  10%!  The 
result:  80%  of  these  programs,  on  the  average,  will  fail  the  first 
time  they  are  run  on  a  computer.  (These  percentages  are  naturally 
not  meant  to  be  accurate.)  In  short,  most  novice  programmers  sel- 
dom see  the  necessity  of  drawing  a  flowchart.  This  usually  results 
in  "unclean"  or  erroneous  programs.  They  must  then  spend  a  long 
time  testing  and  correcting  their  program  (this  is  called  the 


START 


READ  TEMPERATURE  SETTiNG  'T 
ON  THERMOSTAT  BOX 


READ  ACTUAL  ROOM  TEMPERATURE  'R 
FROM  THERMOMETER  OR  OTHER  SENSOR 


IS  T  LESS^ 
THANR 
(ROOM      \OR  EQUAL, 
TOO  COLD)  ^rORJ' 


HEATER  ON 


(OPTIONAL  DELAY) 


(ROOM 
TOOHOTI) 


HEATER  OFF 


(OPTIONAL  DELAY) 


Fig.  1.1:  A  Flowchart  for  Keeping  Room  Temperature  Constant 
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debugging  phase).  The  discipHne  of  flowcharting  is  therefore 
highly  recommended  in  ail  cases.  It  will  require  a  small  amount  of 
additional  time  prior  to  the  coding,  but  will  usually  result  in  a  clear 
program  which  executes  correctly  and  quickly.  Once  flowcharting 
is  well  understood,  a  small  percentage  of  programmers  will  be  able 
to  perform  this  step  mentally  without  having  to  do  it  on  paper.  Un- 
fortunately, in  such  cases  the  programs  that  they  write  will  usual- 
ly be  hard  to  understand  for  anybody  else  without  the  documenta- 
tion provided  by  flowcharts.  As  a  result,  it  is  universally  recom- 
mended that  flowcharting  be  used  as  a  strict  discipline  for  any 
significant  program.  Many  examples  will  be  provided  throughout 
the  book. 

INFORMATION  REPRESENTATION 

All  computers  manipulate  information  in  the  form  of  numbers  or 
in  the  form  of  characters.  Let  us  examine  here  the  external  and 
internal  representations  of  information  m  a  computer. 

INTERNAL  REPRESENTATION  OF  INFORMATION 

All  information  in  a  computer  is  stored  as  groups  of  bits.  A  bit 
stands  for  a  binary  digitV'O"  or  "1").  Because  of  the  limitations 
of  conventional  electronics,  the  only  practical  representation  of  infor- 
mation uses  two-state  logic  (the  representation  of  the  state  "0"  and 
"1").  The  two  states  of  the  circuits  used  in  digital  electronics 
are  generally  "on"  or  "off",  and  these  are  represented  logi- 
cally by  the  symbols  "0"  or  "I".  Because  these  circuits  are 
used  to  implement  "logical"  functions,  they  are  called  "binary 
logic."  As  a  result,  virtually  all  information-processing  today  is 
performed  in  binary  format.  In  the  case  of  microprocessors  in 
general,  and  of  the  Z80  in  particular,  these  bits  are  structured  in 
groups  of  eight.  A  group  of  eight  bits  is  called  a  byte.  A  group  of 
four  bits  is  called  a  nibble. 

Let  us  now  examine  how  information  is  represented  internally  in 
this  binary  format.  Two  entities  must  be  represented  inside  the 
computer.  The  first  one  is  the  program,  which  is  a  sequence  of 
instructions.  The  second  one  is  the  data  on  which  the  program  will 
operate,  which  may  include  numbers  or  alphanumeric  text.  We  will 
discuss  beiow  three  representations:  program,  numbers,  and  alpha- 
numerics. 
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Program  Representation 

All  instructions  are  represented  internally  as  single  or  multiple 
bytes.  A  so-called  "short  instruction"  is  represented  by  a  single 
byte,  A  longer  instruction  will  be  represented  by  two  or  more 
bytes.  Because  the  Z80  is  an  eight-bit  microprocessor,  it  fetches 
bytes  successively  from  its  memory.  Therefore,  a  single-byte 
instruction  always  has  a  potential  for  executing  faster  than  a  two- 
or  three-byte  instruction.  It  will  be  seen  later  that  this  is  an  impor- 
tant feature  of  the  instruction  set  of  any  microprocessor  and  in 
particular  the  Z80,  where  a  special  effort  has  been  made  to  pro- 
vide as  many  single- byte  instructions  as  possible  in  order  to  im- 
prove the  efficiency  of  the  program  execution.  However,  the  limita- 
tion to  8  bits  in  length  has  resulted  in  important  restrictions  which 
will  be  outlined.  This  is  a  classic  example  of  the  compromise  be- 
tween speed  and  flexibility  in  programming.  The  binary  code  used 
to  represent  instructions  is  dictated  by  the  manufacturer.  The 
Z80,  like  any  other  microprocessor,  comes  equipped  with  a-  fixed 
instruction  set.  These  instructions  are  defined  by  the  manufac- 
turer and  are  listed  at  the  end  of  this  book,  with  their  code.  Any 
program  wiU  be  expressed  as  a  sequence  of  these  binary  instruc- 
tions. The  Z80  instructions  are  presented  in  Chapter  4. 

Representing  Numeric  Data 

Representing  numbers  is  not  quite  straightforward,  and  several 
cases  must  be  distinguished.  We  must  first  represent  integers,  then 
signed  numbers,  i.e.,  positive  and  negative  numbers,  and  finally  we 
must  be  able  to  represent  decimal  numbers.  Let  us  now  address 
these  requirements  and  possible  solutions. 

Representing  integers  may  be  performed  by  using  a  direct 
binary  representation.  The  direct  binary  representation  is  simply 
the  representation  of  the  decimal  value  of  a  number  in  the  binary 
system.  In  the  binary  system,  the  right-most  bit  represents  2  to 
the  power  0.  The  next  one  to  the  left  represents  2  to  the  power  1, 
the  next  represents  2  to  the  power  2,  and  the  left-most  bit 
represents  2  to  the  power  7=  128. 

b,b6bjb4b3b,b,b„ 
represents 

b,2'  +  b,2^  +  h,2'  +  b,2'  +  b,2'  +  b,2^  +  b,2'  +  b„2'' 
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The  powers  of  2  are: 

T  =  128.  T  =  64,  2=  =  32,  2'  =  16,  2^  =  8.  2'  =  4,  2'  =  2,  2°  =  1 

The  binary  representation  is  analogous  to  the  decimal  representa- 
tion of  numbers,  where  "123"  represents: 

1  X  100  =  100 
+  2  X  10  =  20 
+  3  X     1  =  3 

=  123 

Note  that  100  =  10^  10  =  10',  1  =  lO^. 

In  this  "positional  notation,"  each  digit  represents  a  power  of  10. 
In  the  binary  system,  each  binary  digit  or  "bit"  represents  a  power 
of  2,  instead  of  a  power  of  10  in  the  decimal  system. 

Example:  "00001001"  in  binary  represents: 


in  decimal: 


1  X  1 

(2=) 

ox  2 

=  0 

(2') 

OX  4 

=  0 

{2=) 

IX  8 

=  8 

(2^) 

0  X  16 

_  0 

(2^i 

0  X  32 

=  0 

(2^) 

0  X  64 

=  0 

(2^) 

0  X  128 

=  0 

=  9 

Let  us  examine  some  more  examples: 
"10000001"  represents: 


IX     1  = 

1 

ox     2  = 

0 

OX     4  = 

0 

ox     8  = 

0 

ox    16  == 

0 

0  X   32  = 

0 

0  X   64  = 

0 

1  X  128  = 

129 

"10000001"  represents,  therefore,  the  decimal  number  129. 
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By  examining  the  binary  representation  of  numbers,  you  will 
understand  why  bits  are  numbered  from  0  to  7,  going  from  right  to 
left.  Bit  0  is  "b^"  and  corresponds  to  2°.  Bit  1  is  "b,"  and  cor- 
responds to  2",  and  so  on. 


Decimal 

Binary 

Decimal 

Binary 

0 

00000000 

32 

00100000 

1 

00000001 

33 

00100001 

2 

00000010 

• 

3 

00000011 

• 

4 

00000100 

* 

5 

00000101 

63 

00111111 

6 

00000110 

64 

01000000 

^ 

00000111 

65 

01000001 

8 

00001000 

■ 

9 

00001001 

10 

00001010 

127 

01111111 

11 

00001011 

128 

10000000 

12 

00001100 

129 

10000001 

13 

00001101 

14 

00001110 

• 

15 

00001111 

16 

00010000 

• 

17 

* 

00010001 

« 

• 
• 

254 

11111110 

31 

OOOUllI 

255 

llllllll 

Fig.  1.2:  Decimai-Binary  Table 


The  binary  equivalents  of  the  numbers  from  0  to  255  are  shown 
in  Fig.  1-2. 

Exercise  1.1:  What  is  the  decimal  value  of  "11112100"? 
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Decimal  to  Binary 

Conversely,  let  us  compute  the  binary  equivalent  of  /'II" 

decimal:  i' 

11^2  =  5  remains  1  —  1  (LSB) 
5  -r-  2  =  2  remains  i  — *  1 
2-2=  j  remams  0  — 0 

1^2=0  remains  1 -*  1  (MSB) 

The  binary  equivalent  is  1011  (read  right-most  coiuixm  from  bot- 
tom to  top). 

The  binary  equivalent  of  a  decimal  number  may  be  obtained  by 
dividing  successively  by  2  until  a  quotient  of  0  is  obtained 

Exercise  1.2:  What  is  the  binary  for  257?  ^    ,  ,  ; 

!  Exercise  1,3:  Convert  19  to  binary,  then  back  to  decimaL 

Operating  on  Binary  Data 

The  arithmetic  rules  for  binary  numbers  are  straightforward. 
The  rules  for  addition  are: 

0-1-0=  .0 
0-Hl=  1 
1  -(-0=  .  1 
i  +  !=(l)  0 

where  (1)  denotes  a  "carry"  of  1  (note  that  "10"  is  the  binary 
equivalent  of  "2"  decimal).  Binary  subtraction  will  be  performed 
by  "adding  the  complement"  and  will  be  explained  once  we  learn 
how  to  represent  negative  numbers. 

Example: 

(2)  10 
+(1)  4-01 

=(3)  11 

Addition  is  performed  just  like  in  decimal,  by  adding  columns, 
from  right  to  left: 

Adding  the  right-most  column: 

io 
+0i: 

(0  +  1=1.  No  carry.) 
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Adding  the  next  column: 

10 
+01 

11         (1  +  0  =1.  No  carry.) 
Exercise  1.4:  Compute  S  +  10  in  binary.  Verify  that  the  result  is  15. 
Some  additional  examples  of  binary  addition:      ['^  '^ 

0010         (2)  0011  (3) 

+0001         (1)  +0001  (1) 

=0011         (3)  =0100  (4) 

This  last  example  illustrates  the  role  of  the  carry. 

Looking  at  the  right-most  bits:  1  +  1  =  (1)  0 

A  carry  of  1  is  generated,  which  must  be  added  to  the  next  bits: 

001  —  column  0  has  just  been  added 
+000  - 
+    1  (carry) 

=    {1)0  —  where  (1 )  indicates  a  new 
carry  into  column  2, 

The  final  result  is:  0100 
Another  example: 

0111  (7) 
+0011      +  (3) 

1010  =(10) 

In  this  example,  a  carry  is  again  generated,  up  to  the  left-most  co- 
lumn. 

Exercise  1.5:  Compute  the  result  of: 

1111 
+0001 
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Does  the  result  hold  in  four  bits? 

With  eight  bits,  it  is  therefore  possible  to  represent  directly  the 
numbers  "00000000"  to  "Ullllll,"  i.e.,  "0"  to  "255".  Two 
obstacles  should  be  visible  immediately.  First,  we  are  only 
representing  positive  numbers.  Second,  the  magnitude  of  these 
numbers  is  limited  to  255  if  we  use  only  eight  bits.  Let  us  address 
each  of  these  problems  in  turn. 

Signed  Binary 

In  a  signed  bmary  representation,  the  left-most  bit  is  used  to  in- 
dicate the  sign  of  the  number.  Traditionally,  "0"  is  used  to  denote 
a  positive  number  while  "1"  is  used  to  denote  a  negative  number. 
Now  "11111111"  will  represent  -127,  while  "Olllllli"  will 
represent  +127.  We  can  now  represent  positive  and  negative 
numbers,  but  we  have  reduced  the  maximum  magnitude  of  these 
numbers  to  127. 

Example:  "0000  0001"  represents  +1  (the  leading  "0"  is  "  +  ", 
foUowed  by  "000  0001"  =  1). 

"1000  0001"  is  -1  {the  leading  "1"  is  "~"). 

Exercise  1, 6:  What  is  the  representation  of  "—5"  in  signed  binary? 

Let  us  now  address  Che  magnitude  problem:  in  order  to  represent 
larger  numbers,  it  will  'be  necessary  to  use  a  larger  number  of  bits. 
For  example,  if  we  use  sixteen  bits  (two  bytes)  to  represent 
numbers,  we  will  be  able  to  represent  numbers  from  — 32K  to 
+32K  in  signed  binary  (IK  in  computer  jargon  represents  1,024). 
Bit  15  is  used  for  the  sign,  and  the  remaining  15  bits  (bit  14  to  bit 
0)  are  used  for  the  magnitude:  2'*  =  32K.  If  this  magnitude  is  still 
too  small,  we  will  use  3  bytes  or  more.  If  we  wish  to  represent  large 
integers,  it  will  be  necessary  to  use  a  larger  number  of  bytes  inter- 
nally to  represent  them.  This  is  why  most  simple  BASlCs,  and 
other  languages,  provide  only  a  limited  precision  for  integers.  This 
way,  they  can  use  a  shorter  internal  format  for  the  numbers  which 
they  manipulate.  Better  versions  of  BASIC,  or  of  these  other 
languages,  provide  a  larger  number  of  significant  decimal  digits  at 
the  expense  of  a  large  number  of  bytes  for  each  number. 

Now  let  us  solve  another  problem,  the  one  of  speed  efficiency. 
We  are  going  to  attempt  performing  an  addition  in  the  signed 
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binary  representation  which  we  have  introduced.  Let  us  add  "—5" 
and  "+7", 

+7  is  represented  by  00000111 
—5  is  represented  by  10000101 

The  binary  sum  is:        10001100,  or  -12 

This  is  not  the  correct  result.  The  correct  result  should  be  +2.  In 
order  to  use  this  representation,  special  actions  must  be  taken,  de- 
pending on  the  sign.  This  results  in  increased  complexity  and  re- 
duced performance.  In  other  words,  the  binary  addition  of  signed 
numbers  does  not  "work  correctly."  This  is  annoying.  Clearly,  the 
computer  must  not  oniy  represent  information,  but  also  perform 
arithmetic  on  it. 

The  solution  to  this  problem  is  called  the  two's  complement 
representation,  which  will  be  used  instead  of  the  signed  binary 
representation.  In  order  to  introduce  two's  complement  let  us  first 
introduce  an  intermediate  step:  one's  complement 

One's  Complement 

In  the  one's  complement  representation,  aU  positive  integers  are 
represented  in  their  correct  binary  format.  For  example  "+3"  is 
represented  as  usual  by  00000011.  However,  its  complement  "—3" 
is  obtained  by  complementing  every  bit  in  the  original  representa- 
tion. Each  0  is  transformed  into  a  1  and  each  1  is  transformed  into 
a  0.  In  our  example,  the  one's  complement  representation  of  "—3" 
will  be  11 11 1100. 

Another  example: 

+2  is  00000010 
-2  is  11111101 

Note  that,  in  this  representation,  positive  numbers  start  with  a 
"0"  on  the  left,  and  negative  ones  with  a  "1"  on  the  left. 

Exercise  1.7:  The  representation  of  "+6"  is  "00000110".  What  is 
the  representation  of  "—5"  in  one's  complement? 

\\\  \  (  ^ 

As  a  test,  let  us  add  minus  4  and  plus  6: 
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-4  is  11111011 
+6  is  00000110 


the  sum  is: 


(1)   00000001  where  (1)  indicates  a 
carry 


The  "correct  result"  should  be  "2",  or  "00000010". 


Let  us  try  again: 


3  is  11111100 
2is  llUUOl 


The  sum  is : 


(1)  11111,001 


or  "-6,"  plus  a  carry.  The  correct  result  should  be  The 
representation  of  "-5"  is  IIHIOIO.  It  did  not  work. 

This  representation  does  represent  positive  and  negative 
numbers.  However  the  result  of  an  ordinary  addition  does  not 
always  come  out  "correctly,"  We  will  use  still  another  representa- 
tion. It  is  evolved  from  the  one's  complement  and  is  called  the 
two's  complement  representation. 

Two's  Complement  Representation 

In  the  two's  complement  representation,  positive  numbers  are 
still  represented,  as  usual,  in  signed  binary,  just  like  in  one's  com- 
plement. The  difference  lies  in  the  representation  of  negative 
numbers.  A  negative  number  represented  in  two's  complement  is 
obtained  by  first  computing  the  one's  complement,  and  then  ad- 
ding one.  Let  us  examine  this  in  an  example: 

+3  is  represented  in  signed  binary  by  00000011.  Its  one's  com- 
plement representation  is  11111100.  The  two's  complement  is  ob- 
tained by  adding  one.  It  is  11111101. 

Let  us  try  an  addition; 


(3) 
-f(5| 


00000011 
-f 00000101 


=(8) 


=00001000 


The  result  is  correct. 
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Let  us  try  a  subtraction: 

(3)  00000011 
{-5)  +11111011 

=11111110 

Let  us  identify  the  result  by  computing  the  two's  complement: 

the  one's  complement  of  11111110  is  00000001 

Adding  1    +  1 

therefore  the  two's  complement  is  00000010  or  +2 

Our  result  above,  "11111110"  represents  "—2",  It  is  correct. 

We  have  now  tried  addition  and  subtraction,  and  the  results  were  correct 
(ignormg  the  carry).  It  seems  that  two's  complement  works! 

What  is  the  two's  complement  representation  of 

What  is  the  two's  complement  representation  of 

Let  us  now  add  +4  and  —3  ithe  subtraction  is  performed  by  add- 
ing the  two's  complement): 

+4  is  00000100 
-3  is  11111101 

The  result  is:  (1)  00000001 

If  we  ignore  the  carry,  the  result  is  00000001,  i.e.,  "1"  in  decimal. 
This  is  the  correct  result.  Without  giving  the  complete  mathe- 
matical proof,  let  us  simply  state  that  this  representation  does 
work.  In  two's  complement,  it  is  possible  to  add  or  subtract  signed 
numbers  regardless  of  the  sign.  Using  the  usual  rules  of  bmary  addi- 
tion, the  result  comes  out  correctly,  including  the  sign.  The  carry 
is  Ignored.  This  is  a  very  significant  advantage.  If  it  were  not  the 
case,  one  would  have  to  correct  the  result  for  sign  every  time,  caus- 
ing a  much  slower  addition  or  subtraction  time. 

For  the  sake  of  completeness,  let  us  state  that  two's  complement 
is  simply  the  most  convenient  representation  to  use  for  simpler 
processors  such  as  microprocessors.  On  complex  processors,  other 
representations  may  be  used.  For  example,  one's  complement  may 
be  used,  but  it  requires  special  circuitry  to  "correct  the  result." 


Exercise  1. 8; 

Exercise  1.9: 
"—128"? 
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From  this  point  on,  all  signed  integers  will  implicitly  be  represented 
internally  in  two's  complement  notation.  See  Fig.  i.3  for  a  table  of 
two's  complement  numbers. 

Exercise  1.10:  What  are  the  smallest  and  the  largest  numbers 
which  one  may  represent  in  two 's  complement  notation,  using  only 
one  byte?  ^ztp-i'^^ 

Exercise  1,11:  Compute  the  two's  complement  of  20.  Then  com- 
pute the  two's  complement  of  your  result.  Do  you  find  20  again? 

The  following  examples  will 'serve  to  demonstrate  the  rules  of  two's 
complement.  In  particular,  C  denotes  a  possible  carry  (or  borrow) 
condition.  {It  is  bit  8  of  the  result.) 

V  denotes  a  two's  complement  overflow,  i.e.,  when  the  sign  of  the 
result  is  changed  "accidentally"  because  the  numbers  are  too 
large.  It  is  an  essentially  internal  carry  from  bit  6  into  bit  7  (the 
sign  bit).  This  will  be  clarified  below. 

Let  us  now  demonstrate  the  role  of  the  carry  "C"  and  the  overflow 

"V". 

The  Carry  C 
Here  is  an  example  of  a  carry: 

(128)  10000000 
+jl29)  +10000001 

(257)  =  (1}  00000001 

where  (1)  indicates  a  carry. 

The  result  requires  a  ninth  bit  (bit  "8",  since  the  right-most  bit  is 
"0").  It  is  the  carry  bit. 

If  we  assume  that  the  carry  is  the  ninth  bit  of  the  result,  we 
recognize  the  result  as  being  100000001  =  257. 

However,  the  carry  must  be  recognized  and  handled  with  care. 
Inside  the  microprocessor,  the  registers  used  to  hold  information 
are  generally  only  eight- bit  wide.When  storing  the  result,  only  bits  0  to 
7  will  be  preserved. 

A  carry,  therefore,  always  requires  special  action:  it  must  be 
detected  by  special  instructions,  then  processed.  Processing  the 
cany  means  either  storing  it  somewhere  (with  a  special  instruc- 
tion), or  ignoring  it,  or  deciding  that  it  is  an  error  {if  the  largest 
authorized  result  is  "111  11 11 1"). 
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2's  complement 

2's  complement 

+ 

code 

code 

+  127 

oiniiii 

-  128 

10000000 

ni  1 1 1 1  in 

1 nnnnnn i 
i  uuuuuu 1 

-4-  1 

mill  tni 

—  1  Zo 

I  nrsnnn  i  n 
I UUUUU 1 u 

-125 

1 00000 il 

X.  fsK 
+  UJ 

O  J 

t  n  1 1 1 1 1 1 

lUl 1 1 1 1 1 

4"  64 

—  o4 

1 1 Uuuuuu 

+  63 

001 11 1 1 1 

-63 

11000001 

fifi  1  fsnnn  i 

1 ini fill 

1  lU i 1  1  i  i 

fViinnnnrs 

UU  E  UUUUU 

—  Ji 

! 1 1 nnnnn 
1 1 J uuuuu 

4-  1  1 

nnni i i i i 

J  1 

1 1 1 nnnni 

1 1 lUUUU I 

-1-  17 

nnnrnnni 

VUU I UUU 1 

1  / 

1 1  i  n  1  i  1 1 

1  I  1 U  i  1  1  1 

-1-  1^^ 

UUU 1 uuuu 

10 

111! nnnn 
1 1 i  i  UUUU 

UUUU 1111 

1  ^ 
—  Ij 

1111 nnn I 

1 1 1 i  UUU  t 

-3-  iA 

UUUUl 1 lU 

i  A 
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1 J  i 1 uu 1 u 

J~  1  ^ 

-r  i  J 

UUUUl lui 
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111! UU 1  I 
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< 

—  J 

1 1 1 1 1  nil 

1 1 1 1 lUI 1 

+  4 

00000100 

-4 

1 1 11 1 100 

+  3 

0000001 1 

-3 

niuioi 

+  2 

00000010 

iiimio 

■f  1 

00000001 

-  1 

iiiiiiii 

+  0 

00000000 

Fig.  1.3:  2's  Comptemenl  Table 
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Overflow  V 
Here  is  an  example  of  overflow: 

bit  6 
bit  7 

f, 

01000000  (64) 
+  01000001  +(65) 

-10000001  ={™127| 

An  internal  carry  has  been  generated  from  bit  6  into  bit  7.  This  is 
called  an  overflow. 

The  result  is  now  negative,  "by  accident."  This  situation  must 
be  detected,  so  that  it  can  be  corrected. 

Let  us  examine  another  situation: 

11111111  (-1) 
+  11111111  +(-1) 

=(1)     lllUUO  =(-2) 

carry 

In  this  case,  an  internal  carry  has  been  generated  from  bit  6  into 
bit  7,  and  also  from  bit  7  into  bit  8  (the  formal  "Carry"  C  we  have 
exammed  in  the  preceding  section).  The  rules  of  two's  complement 
arithmetic  specify  that  this  carry  should  be  ignored.  The  result  is 
then  correct. 

This  is  because  the  carry  from  bit  6  into  bit  7  did  not  change  the 
sign  bit. 

This  is  not  an  overflow  condition.  When  operating  on  negative 
numbers,  the  overflow  is  not  simply  a  carry  from  bit  6  into  bit  7. 
Let  us  examine  one  more  example. 

11000000  (-64) 
+10111111  (-65) 

=(li     01111111  (+127) 

carry 

This  time,  there  has  been  no  internal  carry  from  bit  6  into  bit  7,  but 
there  has  been  an  external  carry.  The  result  is  incorrect,  as  bit  7 
has  been  changed.  An  overflow  condition  should  be  indicated. 
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Overflow  will  occur  in  four  situations: 

1—  adding  large  positive  numbers 

2 —  adding  large  negative  numbers 

3—  subtracting  a  large  positive  number  from  a  large  negative 
number 

4—  subtracting  a  large  negative  number  from  a  large  positive 
number. 

Let  us  now  improve  our  definition  of  the  overflow: 

Technically,  the  overflow  indicator,  a  special  bit  reserved  for  this 
purpose,  and^called  a  "flag,"  will  be  set  when  there  is  a  carry  from 
bit  6  into  bit  7  and  no  external  carry,  or  else  when  there  is  no  carry 
from  bit  6  into  bit  7  but  there  is  an  external  carry.  This  indicates 
that  bit  7,  i.e.,  the  sign  of  the  result,  has  been  accidentally 
changed.  For  the  technically-minded  reader,  the  overflow  flag  is 
set  by  Exclusive  ORing  the  carry-in  and  carry-out  of  bit  7  (the  sign 
bit).  Practically  every  microprocessor  is  supplied  with  a  special 
overflow  flag  to  automatically  detect  this  condition,  wiiich  re- 
quires corrective  action. 

Overflow  indicates  that  the  result  of  an  addition  or  a  subtraction 
requires  more  bits  than  are  available  in  the  standard  eight-bit 
register  used  to  contain  the  result. 

The  Carry  and  the  Overflow 

The  carry  and  the  overflow  bits  are  called  "flags."  They  are  pro- 
vided in  every  microprocessor,  and  in  the  next  chapter  we  will 
learn  to  use  them  for  effective  programming.  These  two  indicators 
are  located  in  a  special  register  called  the  flags  or  "status" 
register.  This  register  also  contains  additional  indicators  whose 
function  will  be  clarified  in  Chapter  4. 

Examples 

Let  us  now  illustrate  the  operation  of  the  carry  and  the  overflow 
in  actual  examples.  In  each  example,  the  symbol  V  denotes  the 
overflow,  and  C  the  carry. 

If  there  has  been  no  overflow.  V  =  0.  If  there  has  been  an 
overflow,  V  =  1  {same  for  the  carry  C).  Remember  that  the  rules  of 
two's  complement  specify  that  the  carry  be  ignored.  (The 
mathematical  proof  is  not  supplied  here.) 
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Posi  tive-Positi  ve 

00000110  (+6) 
+    00001000  (+8) 

=    00001110   (+14)    V:0  C:0 

(CORRECT) 

Positive-Positive  with  Overflow 

01111111  (+127) 
+    00000001  (+1) 

=    10000000   (-128)  V:l  C:0 

The  above  is  invalid  because  an  overflow  has  occurred. 

(ERROR) 

Positive-Negative  (result  positive) 

00000100  (+4) 
+    11111110  (-2) 

={1)00000010   (+2)      V:0         C:l  (disregard) 
(CORRECT) 

Positive-Negative  (result  negative) 

00000010  (+2) 
+    11111100  (-4) 

=    11111110   (-2)      V:0  C:0 

(CORRECT) 

Nega  ti  ve-Negati  ve 

11111110  (-2) 
+    11111100  (-4) 

=(1)11111010   (-6)      V:0         C:l  (disregard) 
(CORRECT) 

Negative-Negative  with  Overflow 

10000001  (-127) 
+    11000010  (-62) 

=(1)01000011        (67)  V;l  C:l 

(ERROR) 
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This  time  an  "underflow"  has  occurred,  by  adding  two  large 
negative  numbers.  The  result  would  be  —189,  which  is  too  large  to 
reside  in  eight  bits. 

Exercise  1.12:  Complete  the  following  additions.  Indicate  the 
result,  the  carry  C,  the  overflow  V,  and  whether  the  result  is  correct 
or  not: 


10111111      (  ) 

+11000001      (  ! 

=   V;   C:  

□  CORRECT       □  ERROR 


11111010      (  ) 

+11111001      {  ) 

=  V:   C:  

□  CORRECT       □  ERROR 


00010000      (  ) 

+01000000      {  ) 

=  Vi   c-  

□  CORRECT       □  ERROR 


01111110      (  ) 

+00101010      {  j 

=  V:   C:  

□  CORRECT       □  ERROR 


Exercise  1. 13:  Can  you  show  an  example  of  overflow  when  adding  a 
positive  and  a  negative  number?  Why? 

Fixed  Format  Representation 

Now  we  know  how  to  represent  signed  integers.  However,  we 
have  not  yet  resolved  the  problem  of  magnitude.  If  we  want  to 
represent  larger  integers,  we  will  need  several  bytes.  In  order  to 
perform  arithmetic  operations  efficiently,  it  is  necessary  to  use  a 
fixed  number  of  bytes  rather  than  a  variable  one.  Therefore,  once 
the  number  of  bytes  is  chosen,  the  maximum  magnitude  of  the 
number  which  can  be  represented  is  fixed. 

Exercise  1.14:  What  are  the  largest  and  the  smallest  numbers 
which  may  be  represented  in  two  bytes  using  two's  complement? 

The  Magnitude  Problem 

When  adding  numbers  we  have  restricted  ourselves  to  eight  bits 
because  the  processor  we  will  use  operates  internally  on  eight  bits 
at  a  time.  However,  this  restricts  us  to  the  numbers  in  the  range 
—128  to  +127.  Clearly,  this  is  not  sufficient  for  many  applications. 

Multiple  precision  will  be  used  to  increase  the  number  of  digits 
which  can  be  represented.  A  two-,  three-,  or  N-byte  format  may 
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then  be  used.  For  example,  let  us  examine  a  16-bit,  "double-pre- 
cision" format: 

00000000  00000000  is  "0" 
00000000      00000001      is  "1" 

01111111      Uinill      IS  "32767" 
lUlllll      11111111  is"-l" 
11111111      11111110      is  "-2" 

Exercise  1,15:  What  is  the  largest  negative  integer  which  can  be 
represented  in  a  two's  complement  triple-precision  format? 

However,  this  method  will  result  in  disadvantages.  When  adding 
two  numbers,  for  example,  we  will  generally  have  to  add  them 
eight  bits  at  a  time.  This  will  be  explained  in  Chapter  3  (Basic  Pro- 
gramming Techniques).  It  results  in  slower  processing.  Also,  this 
representation  uses  16  bits  for  any  number,  even  if  it  could  be 
represented  with  only  eight  bits.  It  is,  therefore,  common  to  use  16 
or  perhaps  32  bits,  but  seldom  more. 

Let  us  consider  the  following  important  point:  whatever  the 
number  of  bits  N  chosen  for  the  two's  complement  representation, 
it  is  fixed.  If  any  result  or  intermediate  computation  should 
generate  a  number  requiring  more  than  N  bits,  some  bits  will  be 
lost.  The  program  normally  retains  the  N  left-most  bits  {the  most 
significant)  and  drops  the  low-order  ones.  This  is  called  truncating 
the  result. 

Here  is  an  example  in  the  decimal  system,  using  a  six  digit 
representation: 

123456 
X  1.2 


246912 
123456 

=  148147,2 


The  result  requires  7  digits!  The  "2"  after  the  decimal  point  will  be 
dropped  and  the  final  result  will  be  148147.  It  has  been  truncated. 
Usually,  as  long  as  the  position  of  the  decimal  point  is  not  lost,  this 
method  is  used  to  extend  the  range  of  the  operations  which  may  be 
performed,  at  the  expense  of  precision. 
The  problem  is  the  same  in  binary.  The  details  of  a  binary  multi- 
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plication  will  be  shown  in  Chapter  4. 

This  fixed-format  representation  may  cause  a  loss  of  precision, 
but  it  may  be  sufficient  for  usual  computations  or  mathematical 
operations. 

Unfortunately,  in  the  case  of  accounting,  no  loss  of  precision  is 
tolerable.  For  example,  if  a  customer  rings  up  a  large  total  on  a 
cash  register,  it  would  not  be  acceptable  to  have  a  five  figure 
amount  to  pay,  which  would  be  approximated  to  the  dollar. 
Another  representation  must  be  used  wherever  precision  in  the 
result  is  essential.  The  solution  normally  used  is  BCD,  or 
binary-coded  decimal. 

BCD  Representation 

The  principle  used  in  representing  numbers  in  BCD  is  to  encode 
each  decimal  digit  separately,  and  to  use  as  many  bits  as  necessary 
to  represent  the  complete  number  exactly.  In  order  to  encode  each 
of  the  digits  from  0  through  9,  four  bits  are  necessary.  Three  bits 
would  only  supply  eight  combinations,  and  can  therefore  not  en- 
code the  ten  digits.  Four  bits  allow  sixteen  combinations  and  are 
therefore  sufficient  to  encode  the  digits  "0"  through  "9",  It  can 
also  be  noted  that  six  of  the  possible  codes  will  not  be  used  in  the 
BCD  representation  {see  Fig.  1-4),  This  will  result  later  on  in  a  potential 
problem  during  additions  and  subtractions,  which  we  will  have  to  solve. 


BCD 

BCD 

CODE 

SYMBOL 

CODE 

SYMBOL 

0000 

0 

1000 

8 

0001 

1 

1001 

9 

0010 

2 

1010 

unused 

0011 

3 

1011 

unused 

0100 

4 

1100 

unused 

0101 

5 

110! 

unused 

Olio 

6 

1110 

unused 

0111 

7 

1111 

unused 

Fig.  1.4:  BCD  Table 
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Since  only  four  bits  are  needed  to  encode  a  BCD  digit,  two  BCD  digits 
may  be  encoded  in  every  byte.  This  is  called  "packed  BCD. " 

As  an  example,  "00000000"  will  be  "00"  in  BCD.  "10011001" 
will  be  "99", 

A  BCD  code  is  read  as  follows; 

0010  0001 

BCD  digit  "2" 
BCD  digit  "1" 
BCD  number  "21" 

Exercise  J.  16:    What  is  the  BCD  representation  for  "29"'^  'VI "? 

Exercise  1.17:   Is  "10100000''  a  valid  BCD  representation?  Why? 

As  many  bytes  as  necessary  will  be  used  to  represent  all  BCD 
digits.  Typically,  one  or  more  nibbles  will  be  used  at  the  beginning 
of  the  representation  to  indicate  the  total  number  of  nibbles,  i.e., 
the  total  number  of  BCD  digits  used.  Another  nibble  or  byte  will 
be  used  to  denote  the  position  of  the  decimal  point.  However,  con- 
ventions may  vary. 

Here  is  an  example  of  a  representation  for  multibyte  BCD  in- 
tegers: 


+ 


1 


™]    (3  bytes) 


number 
of  digits 
(up  to  255)  sign 


number  "221' 


This  represents  +221 

(The  sign  may  be  represented  by  0000  for  +,  and  0001  for  — ,  for 
example.) 

Exercise  LIS:  Using  the  same  convention,  represent  "—23123": 
Show  it  in  BCD  format,  as  above,  then  in  binary. 

Exercise  1.19:  Show  the  BCD  for  "222"  and  "111 ",  then  for  the  re- 
sult of  222  X  111.  (Compute  the  result  by  hand,  then  show  it  in  the 
above  representation.) 

The  BCD  representation  can  easily  accommodate  decimal 
numbers. 


36 


BASIC  CONCEPTS 


For  example,  +2.21  may  be  represented  by: 


digit  3 

digit  2 

digit  i 

3 

2 

+ 

i. 

2 

1 

t  y  y 

3  digits        "."is  on  the  + 
left  of  digit  2 


221 


The  advantage  of  BCD  is  that  it  yields  absolutely  correct 
results.  Its  disadvantage  is  that  it  uses  a  large  amount  of  memory 
and  results  in  slow  arithmetic  operations.  This  is  acceptable  only 
in  an  accounting  environment  and  is  normally  not  used  in  other 
cases. 

Exercise  1.20:  How  many  bits  are  required  to  encode  "9999"  in 
BCD?  And  in  two's  complement? 

We  have  now  solved  the  problems  associated  with  the  represen- 
tation of  integers,  signed  integers  and  even  large  integers.  We 
have  even  already  presented  one  possible  method  of  representing 
decimal  numbers,  with  BCD  representation.  Let  us  now  examine 
the  problem  of  representing  decimal  numbers  in  a  fixed  length  for- 
mat. 


Floating-Point  Representation 

The  basic  principle  is  that  decimal  numbers  must  be  represented 
with  a  fixed  format.  In  order  not  to  waste  bits,  the  representation 
will  normalize  all  the  numbers. 

For  example,  "0.000123"  wastes  three  zeros  on  the  left  of  the 
number,  which  have  no  meaning  except  to  indicate  the  position  of 
the  decimal  point.  Normalizing  this  number  results  in  .123  X  10-^ 
".123"  is  called  a  normalized  mantissa,  "—3"  is  called  the  expo- 
nent. We  have  normalized  this  number  by  eliminating  all  the  meaning- 
less zeros  on  the  left  of  it  and  adjusting  the  exponent. 

Let  us  consider  another  example: 
22.1  is  normalized  as  ,221  x  10' 

or  M  X  10^  where  M  is  the  mantissa,  and  E  is  the  exponent. 
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It  can  be  readily  seen  that  a  normalized  number  is  characterized 
by  a  mantissa  less  than  1  and  greater  or  equal  to  .1  in  all  cases 
where  the  number  is  not  zero.  In  other  words,  this  can  be  repre- 
sented mathematically  by: 

.1  <  M  <  1  or  10-'  <  M  <  10° 

Similarly,  in  the  binary  representation: 

2-'<M<2''  (or  .5<M<1) 

Where  M  is  the  absolute  value  of  the  mantissa  (disregarding  the 
signi. 

For  example; 

111.01  is  normalized  as:  ,11101  X  1\ 

The  mantissa  is  U 101 . 

The  exponent  is  3, 

Now  that  we  have  defined  the  principle  of  the  representation, 
let  us  examine  the  actual  format.  Atypical  floating-point  represen- 
tation appears  below. 
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24  23 

— I — r 


S6  15 


EXP 


8  7 
 1  

S     S  / 

i 


Fig.  1.5:  Typical  Floating-Point  Representation 


In  the  representation  used  in  this  example,  four  bytes  are  used 
for  a  total  of  32  bits.  The  first  byte  on  the  left  of  the  illustration  is 
used  to  represent  the  exponent.  Both  the  exponent  and  the  man- 
tissa will  be  represented  in  two's  complement.  As  a  result,  the 
maximum  exponent  will  be  -128.  "S"  in  Fig.  1-5  denotes  the  sign 
bit. 

Three  bytes  are  used  to  represent  the  mantissa.  Since  the  first 
bit  in  the  two's  complement  representation  indicates  the  sign,  this 
leaves  23  bits  for  the  representation  of  the  magnitude  of  the  man- 
tissa. 
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Exercise  1.21:  How  many  decimal  digits  can  the  mantissa  repre- 
sent with  the  23  bits? 

This  is  only  one  example  of  a  floating  point  representation.  It  is 
possible  to  use  only  three  bytes,  or  it  is  possible  to  use  more.  The 
four-byte  representation  proposed  above  is  just  a  common  one 
which  represents  a  reasonable  compromise  in  terms  of  accuracy, 
magnitude  of  numbers,  storage  utilization,  and  efficiency  in 
arithmetic  operation. 

We  have  now  explored  the  problems  associated  with  the  rep- 
resentation of  numbers  and  we  know  how  to  represent  them  in  in- 
teger form,  with  a  sign,  or  in  decimal  form.  Let  us  now  examine 
how  to  represent  alphanumeric  data  internally. 

Representing  Alphanumeric  Data 

The  representation  of  alphanumeric  data,  i.e.  characters,  is  com- 
pletely straightforward:  all  characters  are  encoded  in  an  eight-bit 
code.  Only  two  codes  are  m  general  use  in  the  computer  world,  the 
ASCII  Code,  and  the  EBCDIC  Code.  ASCII  stands  for  "American 
Standard  Code  for  Information  Interchange,"  and  is  universally 
used  in  the  world  of  microprocessors.  EBCDIC  is  a  variation  of 
ASCII  used  by  IBM,  and  therefore  not  used  in  the  microcomputer 
world  unless  one  interfaces  to  an  IBM  terminal. 

Let  us  briefly  examine  the  ASCII  encoding.  We  must  encode  26 
letters  of  the  alphabet  for  both  upper  and  lower  case,  plus  10 
numeric  symbols,  plus  perhaps  20  additional  special  symbols.  This 
can  be  easily  accomplished  with  7  bits,  which  allow  128  possible 
codes.  (See  Fig. 1-6.)  All  characters  are  therefore  encoded  in  7  bits. 
The  eighth  bit,  when  it  is  used,  is  the  parity  bit.  Parity  is  a  tech- 
nique for  verifying  that  the  contents  of  a  byte  have  not  been  ac- 
cidentally changed.  The  number  of  I's  in  the  byte  is  counted  and 
the  eighth  bit  is  set  to  one  if  the  count  was  odd,  thus  making  the 
total  even.  This  is  called  even  parity.  One  can  also  use  odd  parity, 
i.e.  writing  the  eighth  bit  {the  left-most)  so  that  the  total  number  of 
I's  in  the  byte  is  odd. 

Example:  Jet  us  compute  the  parity  bit  for  "0010011"  using  even 
parity.  The  number  of  I's  is  3.  The  parity  bit  must  therefore  be  a  1 
so  that  the  total  number  of  bits  is  4,  i.e.  even.  The  result  is 
10010011,  where  the  leading  1  is  the  parity  bit  and  0010011  iden- 
tifies the  character. 
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The  table  of  7-bit  ASCII  codes  is  shown  in  Fig.  1-6.  In  practice,  it 
IS  used  "as  is,"  i.e.  without  parity,  by  adding  a  0  in  the  left-most 
position,  or  else  with  parity,  by  adding  the  appropriate  extra  bit  on 
the  left. 

Exercise  1.22:  Compute  the  8-bit  representation  of  the  digits  "0" 
through  using  even  parity.  (This  code  will  be  used  in  applica- 
tion examples  of  Chapter  8.) 

Exercise  1.23:  Same  for  the  letters  "A"  through  "F". 

Exercise  1.24:  Using  a  non-parity  ASCII  code  (where  the  left-most 
bit  is  "0"),  indicate  the  binary  contents  of  the  4  characters  below: 

"A" 

"3" 
"b" 


HEX 

MSD 

0 

1 

001 

2 
010 

3 
011 

4 
100 

5 
101 

6 
110 

7 

111 

LSD 

BITS 

000 

0 

0000 

NUL 

DLE 

SPACE 

0 

@ 

P 

P 

1 

0001 

SOH 

DC1 

! 

1 

A 

Q 

a 

q 

2 

0010 

STX 

DC2 

2 

B 

R 

b 

r 

3 

0011 

ETX 

DCS 

# 

3 

C 

S 

c 

s 

4 

0100 

EOT 

DC4 

s 

4 

D 

T 

d 

t 

5 

0101 

ENQ 

NAK 

% 

5 

E 

U 

e 

u 

6 

0110 

ACK 

SYN 

& 

6 

F 

V 

f 

V 

7 

0111 

BEL 

ETB 

7 

G 

w 

g 

w 

3 

1000 

BS 

CAN 

{ 

B 

H 

X 

h 

X 

9 

1001 

HT 

EM 

) 

9 

i 

Y 

1 

V 

A 

1010 

LF 

SUB 

J 

Z 

1 

z 

B 

1011 

VT 

ESC 

K 

[ 

k 

[ 

C 

1100 

FF 

FS 

< 

L 

\ 

1 

D 

1101 

CR 

QS 

M 

] 

m 

I 
1 

E 

1110 

SO 

RS 

> 

N 

A 

n 

/w 

F 

1111 

SI 

US 

/ 

n 

0 

0 

DEL 

Fig.  1.6:  ASCII  Conversion  Table 
(see  Appendix  D  for  abbreviations) 

In  specialized  situations  such  as  telecommunications,  other 
codings  may  be  used  such  as  error-correcting  codes.  However  they 
are  beyond  the  scope  of  this  book. 
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We  have  examined  the  usual  representations  for  both  program 
and  data  inside  the  computer.  Let  us  now  examme  the  possible  ex- 
ternal representations. 


EXTERNAL  REPRESENTA  TION  OF  INFORMATION 

The  external  representation  refers  to  the  way  mformation  is  pre- 
sented to  the  user,  i.e.  generally  to  the  programmer.  Information 
may  be  presented  externally  in  essentially  three  formats:  binary, 
octal  or  hexadecimal  and  symbolic. 

1.  Binary 

It  has  been  seen  that  information  is  stored  internally  in  bytes, 
which  are  sequences  of  eight  bits  lO's  or  I's).  It  is  sometimes 
desirable  to  display  this  internal  information  directly  in  its  binary 
format  and  this  is  called  binary  representation.  One  simple  exam- 
ple is  provided  by  Light  Emitting  Diodes  (LEDst  which  are  essen- 
tially miniature  lights,  on  the  front  panel  of  the  microcomputer.  In 
the  case  of  an  eight-bit  microprocessor,  a  front  panel  will  typically 
be  equipped  with  eight  LEDs  to  display  the  contents  of  any  inter- 
nal register.  (A  register  is  used  to  hold  eight  bits  of  information 
and  will  be  described  in  Chapter  2).  A  lighted  LED  indicates  a  one. 
A  zero  is  indicated  by  an  LED  which  is  not  lighted.  Such  a  binary 
representation  may  be  used  for  the  fine  debugging  of  a  complex 
program,  especially  if  it  involves  input/output,  but  is  naturally 
impractical  at  the  human  level.  This  is  because  in  most  cases,  one 
likes  to  look  at  information  in  symbolic  form.  Thus  "9"  is  much 
easier  to  understand  or  remember  than  "1001".  More  convenient 
representations  have  been  devised,  which  improve  the  person- 
machine  interface. 

2.  Octal  and  Hexadecimal 

"Octal"  and  "hexadecimal"  encode  respectively  three  and  four 
binary  bits  into  a  unique  symbol.  In  the  octal  system,  any 
combination  of  three  binary  bits  is  represented  by  a  number  be- 
tween 0  and  7. 

"Octal"  is  a  format  using  three  bits,  where  each  combination  of 
three  bits  is  represented  by  a  symbol  between  0  and  7: 
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binary 

octal 

0 

nni 

\J\J  X 

1 

010 

2 

oil 

3 

100 

4 

101 

5 

no 

6 

111 

Fig.  1.7:  Octal  Symbols 


For  example,  "00   100   100"  binary  is  represented  by: 

T    r  Y 

0      4  4 
or  "044"  in  octal. 

Another  example:  11    111    111  is: 

T    T  y 

3      7  7 

or  "377"  in  octal. 
Conversely,  the  octal  "211"  represents: 

010    001  001 

or  "10001001"  binary. 

Octal  has  traditionally  been  used  on  older  computers  which  were 
employing  various  numbers  of  bits  ranging  from  8  to  perhaps  64, 
More  recently,  with  the  dominance  of  eight-bit  microprocessors, 
the  eight-bit  format  has  become  the  standard,  and  another  more 
practical  representation  is  used.  This  is  hexadecimal. 

In  the  hex  decimal  representation,  a  group  of  four  bits  is  en- 
coded as  one  hexadecimal  digit.  Hexadecimal  digits  are 
represented  by  the  symbols  from  0  to  9,  and  by  the  letters  A,  B,  C, 
D.  E,  F.  For  example,  "0000"  is  represented  by  "0",  "0001"  is 
represented  by  "1"  and  "1111"  is  represented  by  the  letter  "F" 
(see  Fig.  i-8). 
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16 

15 

1111 

F 

17 

Fig.  1.8:  Hexadecimal  Codes 


43 


PROGRAMMING  THE  Z80 


Example:  1010  0001  in  binary  is  represented  by 
A       1    in  hexadecimal. 

Exercise  1.25:  What  is   the   hexadecimal  representation  of 
"10101010?' 

Exercise  1.26:  Conversely,  what  is  the  binary  equivalent  of  "FA  " 
hexadecimal? 

Exercise  1.27:   What  is  the  octal  of  "01000001 "? 

Hexadecimal  offers  the  advantage  of  encoding  eight  bits  into  on- 
ly two  digits.  This  is  easier  to  visualize  or  memorize  and  faster  to 
type  into  a  computer  than  its  binary  equivalent.  Therefore,  on 
most  new  microcomputers,  hexadecimal  is  the  preferred  method  of 
representation  for  groups  of  bits. 

Naturally,  whenever  the  information  present  in  the  memory  has 
a  meaning,  such  as  representing  text  or  numbers,  hexadecimal  is 
not  convenient  for  representing  the  meaning  of  this  information 
when  it  is  brought  out  for  use  by  humans. 

Symbolic  Representation 

Symbolic  representation  refers  to  the  external  representation  of 
information  in  actual  symbolic  form.  For  example,  decimal  num- 
bers are  represented  as  decimal  numbers,  and  not  as  sequences  of 
hexadecimal  symbols  or  bits.  Similarly,  text  is  represented  as 
such.  Naturally,  symbolic  representation  is  most  practical  to  the 
user.  It  is  used  whenever  an  appropriate  display  device  is 
available,  such  as  a  CRT  display  or  a  printer.  (A  CRT  display  is  a 
teievision-type  screen  used  to  display  text  or  graphics,)  Unfortu- 
nately, in  smaller  systems  such  as  one-board  microcomputers,  it  is 
uneconomical  to  provide  such  displays,  and  the  user  is  restricted 
to  hexadecimal  communication  with  the  computer. 

Summary  of  External  Representations 

Symbolic  representation  of  information  is  the  most  desirable 
since  it  is  the  most  natural  for  a  human  user.  However,  it  requires 
an  expensive  interface  in  the  form  of  an  alphanumeric  keyboard, 
plus  a  printer  or  a  CRT  display.  For  this  reason,  it  may  not  be 
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available  on  the  less  expensive  systems.  An  alternative  type  of  rep- 
resentation is  then  used,  and  in  ttiis  case  hexadecimal  is  the  domi- 
nant representation.  Only  in  rare  cases  relating  to  fine  de-bugging 
at  the  hardware  or  the  software  level  is  the  binary  representation 
used.  Binary  directly  displays  the  contents  of  registers  of  memory 
in  binary  format. 

(The  utility  of  a  direct  binary  display  on  a  front  panel  has  always 
been  the  subject  of  a  heated  emotional  controversy,  which  will  not 
be  debated  here.) 

We  have  seen  how  to  represent  information  internally  and  exter- 
nally. We  will  now  examine  the  actual  microprocessor  which  will 
manipulate  this  information. 

Additional  Exercises 

Exercise  1,28:  What  is  the  advantage  of  two's  complement  over 
other  representations  used  to  represent  signed  numbers? 

Exercise  1.29:  How  would  you  represent  "1024"  in  direct  binary? 
Signed  binary?  Two's  complement? 

Exercise  IJO:  What  is  the  V-bit?  Should  the  programmer  test  it 
after  an  addition  or  subtraction? 

Exercise  1.31:  Compute  the  two's  complement  of  "-hid".,  "+17", 
"+18",  "-16",  "-17".  "-18". 

Exercise  1.32:  Show  the  hexadecimal  representation  of  the  follow- 
ing text,  which  has  been  stored  internally  in  ASCII  format,  with 
no  parity:  =  "MESSAGE". 
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INTRODUCTION 

In  order  to  program  at  an  elementary  level,  it  is  not  necessary  Co 
understand  in  detail  the  internal  structure  of  the  processor  that  one  iS 
using.  However,  in  order  to  do  efficient  programming,  such  an 
understanding  is  required.  The  purpose  of  this  chapter  is  to  present  the 
basic  hardware  concepts  necessary  for  understanding  the  operation  of 
the  Z80  system.  The  complete  microcomputer  system  includes  not  only 
the  microprocessor  unit  (here  the  Z80),  but  also  other  components. 
This  chapter  presents  the  Z80  proper,  while  the  other  devices  {mainly 
input/output)  will  be  presented  in  a  separate  chapter  (Chapter  7). 

We  will  review  here  the  basic  architecture  of  the  microcomputer 
system,  then  study  more  closely  the  internal  organization  of  the  Z80. 
We  will  examine,  in  particular,  the  various  registers.  We  will  then  study 
the  program  execution  and  sequencing  mechanism.  From  a  hardware 
standpoint,  this  chapter  is  only  a  simplified  presentation.  The  reader  in- 
terested in  gaining  detailed  understanding  is  referred  to  our  book  ref. 
C20I  ("Microprocessors,"  by  the  same  author). 

The  280  was  designed  as  a  replacement  for  the  Intel  8080,  and  to  of- 
fer additional  capabilities.  A  number  of  references  will  be  made  in  this 
chapter  to  the  8080  design. 

SYSTEM  ARCHITECTURE 

The  architecture  of  the  microcomputer  system  appears  m  Figure  2.1. 
The  microprocessor  unit  (MPU),  which  will  be  a  Z80  here,  appears  on 
the  left  of  the  illustration.  It  implements  the  functions  of  a  central- 
processing  unit  (CPU)  withm  one  chip:  it  includes  an  arithmetic-logical 
unit  (ALU),  plus  its  internal  registers,  and  a  control  unit  (CU),  in 


46 


280  HARDWARE  ORGANIZATION 

charge  of  sequencing  the  system.  Its  operation  will  be  explained  m  this 
chapter. 


IC 


Z80 
RST 


2 


ROM 


302 


RAM 


IC 


0> 


1> 
0> 


Fig.  2.1:  Standard  280  System 

The  MPU  creates  three  buses:  an  8-bit  bidirectional  data  bus,  which 
appears  at  the  top  of  the  illustration,  a  16-bit  unidirectional  address 
bus.  and  a  control  bus.  which  appears  at  the  bottom  of  the  illustration. 
Let  us  describe  the  function  of  each  of  the  buses. 

The  data  bus  carries  the  data  being  exchanged  by  the  various  ele- 
ments of  the  system.  Typically,  it  will  carry  data  from  the  memory  to 
the  MPU  or  from  the  MPU  to  the  memory  or  from  the  MPU  to  an  in- 
put/output chip.  (An  input/output  chip  is  a  component  m  charge  of 
communicating  with  an  external  device.) 

The  address  bus  carries  an  address  generated  by  the  MPU,  which  will 
select  one  internal  register  within  one  of  the  chips  attached  to  the 
system.  This  address  specifies  the  source,  or  the  destination,  of  the  data 
which  will  transit  along  the  data  bus. 

The  control  bus  carries  the  various  synchronization  signals  required 
by  the  system. 

Having  described  the  purpose  of  buses,  let  us  now  connect  the  addi- 
tional components  required  for  a  complete  system. 

Every  MPU  requires  a  precise  timing  reference,  which  is  supplied  by 
a  clock  and  a  crystal.  In  most  "older"  microprocessors,  the  clock-oscil- 
iator  is  external  to  the  MPU  and  requires  an  extra  chip.  In  most  recent 
microprocessors,  the  clock-osciiiator  is  usually  incorporated  within  the 
MPU.  The  quartz  crystal,  however,  because  of  its  bulk,  is  always  exter- 
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nal  to  the  system.  The  crystal  and  the  clock  appear  on  the  left  of  the 
MPU  box  in  Figure  2.1. 

Let  us  now  turn  our  attention  to  the  other  elements  of  the  system. 
Going  from  left  to  right  on  the  illustration,  we  distinguish: 

The  ROM  is  the  read-only  memory  and  contains  the  program  for  the 
system.  The  advantage  of  the  ROM  memory  is  that  its  contents  are  per- 
manent and  do  not  disappear  whenever  the  system  is  turned  off.  The 
ROM,  therefore,  always  contains  a  bootstrap  or  a  monitor  program 
(their  function  will  be  explained  later)  to  permit  initial  system  opera- 
tion. In  a  process-control  environment,  nearly  all  the  programs  will 
reside  in  ROM,  as  they  will  probably  never  be  changed.  In  such  a  case, 
the  industrial  user  has  to  protect  the  system  against  power  failures;  pro- 
grams must  not  be  volatile.  They  must  be  in  ROM. 

However,  in  a  hobbyist  environment,  or  in  a  program-development 
environment  (when  the  programmer  tests  his  program),  most  of  the 
programs  will  reside  in  RAM  so  that  they  can  be  easily  changed.  Later, 
they  may  remain  in  RAM,  or  be  transferred  into  ROM,  if  desired. 
RAM,  however,  is  volatile.  Its  contents  are  lost  when  power  is  turned 
off. 

The  RAM  (random-access  memory)  is  the  read/write  memory  for  the 
system.  In  the  case  of  a  control  system,  the  amount  of  RAM  will 
typically  be  small  (for  data  only).  On  the  other  hand,  in  a  program- 
development  environment,  the  amount  of  RAM  will  be  large,  as  it  will 
contain  programs  pius  development  software.  All  RAM  contents  must 
be  loaded  prior  to  use  from  an  external  device. 

Finally  the  system  will  contain  one  or  more  interface  chips  so  that  it 
may  communicate  with  the  external  world.  The  most  frequently  used 
interface  chip  is  the  PIO  or  parallel  input/output  chip.  It  is  the  one 
shown  on  the  illustration.  This  PIO,  like  all  other  chips  in  the  system, 
connects  to  all  three  buses  and  provides  at  least  two  8- bit  ports  for 
communication  with  the  outside  world.  For  more  details  on  how  an  ac- 
tual PIO  works,  refer  to  book  C201  or,  for  specifics  of  the  Z80  system, 
refer  to  Chapter  7  (Input/Output  Devices). 

All  the  chips  are  connected  to  all  three  buses,  including  the  control 
bus. 

The  functional  modules  which  have  been  described  need  not 
necessarily  reside  on  a  single  LSI  chip.  In  fact,  we  could  use  combina- 
tion chips,  which  may  include  both  PIO  and  a  limited  amount  of  ROM 
or  RAM. 

Still  more  components  will  be  required  to  build  a  real  system.  In  par- 
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ticular,  the  buses  usually  need  to  be  buffered.  Also,  decoding  logic  may 
be  used  for  the  memory  RAM  chips,  and,  finally,  some  signals  may 
need  to  be  amplified  by  drivers.  These  auxiliary  circuits  will  not  be 
described  here  as  they  are  not  relevant  to  programming.  The  reader  m- 
terested  in  specific  assembly  and  interfacing  techniques  is  referred  to 
book  C207  "Microprocessor  interfacmg  Techniques." 

INSIDE  A  MICROPROCESSOR 

The  large  majority  of  all  microprocessor  chips  on  the  market  today 
implement  the  same  architecture.  This  "standard"  architecture  will  be 
described  here.  It  is  shown  in  Figure  2.2.  The  modules  of  this  standard 
microprocessor  will  now  be  detailed,  from  right  to  left. 


EXTERNAL  DATA  BUS 
INTERNAL  BUS ' 


^  (8  BITS) 


Fig.  2.2:  "Standard"  Microprocessor  Architecture 


The  control  box  on  the  right  represents  the  control  unit  which  syn- 
chronizes the  entire  system.  Its  role  will  be  clarified  within  the  re- 
mainder of  this  chapter. 
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The  ALU  performs  arithmetic  and  logic  operations.  A  special 
register  equips  one  of  the  inputs  of  the  ALU,  the  left  input  here.  It  is 
called  the  accumulator.  (Several  accumulators  may  be  provided.)  The 
accumulator  may  be  referenced  both  as  input  and  output  (source  and 
destination)  within  the  same  instruction. 

The  ALU  must  also  provide  shift  and  rotate  facilities. 

A  shift  operation  consists  of  moving  the  contents  of  a  byte  by  one  or 
more  positions  to  the  left  or  to  the  right.  This  is  illustrated  in  Figure 
2.3.  Each  bit  has  been  moved  to  the  left  by  one  position.  The  details  of 
shifts  and  rotations  will  be  presented  in  the  next  chapter. 


SHIFTLEFT 


r 

^  r 

^  r 

^  r 

\  r 
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ROTATE  tEFT 


r|^  4^' 


r\ r\  r\  r\ 


CARRY 


Note:  Some  Shift  and  Rotate  instructtons  do  not  include  the  Carry. 
Fig.  2.3:  Shift  and  Rotate 


The  shifter  may  be  on  the  ALU  output,  as  illustrated  in  Figure  2.2,  or 
may  be  on  the  accumulator  input. 

To  the  left  of  the  ALU,  the //ergs  or  status  register  appear.  Their  role 
IS  to  store  exceptional  conditions  within  the  microprocessor.  The  con- 
tents of  the  flags  register  may  be  tested  by  specialized  instructions,  or 
may  be  read  on  the  internal  data  bus.  A  condiiional  instruction  will 
cause  the  execution  of  a  new  program,  depending  on  the  value  of  one  of 
these  bits. 

The  role  of  the  status  bits  in  the  Z80  will  be  examined  later  in  this 
chapter. 
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Setting  Flags 

Most  of  the  instructions  executed  by  the  processor  will  modify  some 
or  all  of  the  flags.  It  is  important  to  always  refer  to  the  chart  provided 
by  the  manufacturer  listing  which  bits  will  be  modified  by  the  instruc- 
tions. This  is  essential  m  understanding  the  way  a  program  is  being  ex- 
ecuted. Such  a  chart  for  the  Z80  is  shown  in  Figure  4-17. 

The  Registers 

Let  us  look  now  at  Figure  2.2.  On  the  left  of  the  illustration,  the  reg- 
isters of  the  microprocessor  appear.  Conceptually,  one  can  distinguish 
the  general  purpose  registers  and  the  address  registers. 

The  General-Purpose  Registers 

General-purpose  registers  must  be  provided  in  order  for  the  ALU  to 
manipulate  data  at  high  speed.  Because  of  restrictions  on  the  number  of 
bits  which  it  is  reasonable  to  provide  within  an  instruction,  the  number 
of  (directly  addressable)  registers  is  usually  limited  to  fewer  than  eight. 
Each  of  these  registers  is  a  set  of  eight  flip-flops,  connected  to  the 
bidirectional  internal  data  bus.  These  eight  bits  can  be  transferred 
simultaneously  to  or  from  the  data  bus.  The  implementation  of  these 
registers  in  MOS  flip-flops  provides  the  fastest  level  of  memory 
available,  and  their  contents  can  be  accessed  within  tens  of 
nanoseconds. 

Internal  registers  are  usually  labelled  from  0  to  n.  The  role  of  these 
registers  is  not  defined  in  advance:  they  are  said  to  be  "general 
purpose."  They  may  contain  any  data  used  by  the  program. 

These  general-purpose  registers  will  normally  be  used  to  store  eight- 
bit  data.  On  some  microprocessors,  facilities  exist  to  manipulate  two  of 
these  registers  at  a  time.  They  are  then  called  "register  pairs."  This  ar- 
rangement facilitates  the  storage  of  16-bit  quantities,  whether  data  or 
addresses. 

The  Address  Registers 

Address  registers  are  16-bit  registers  intended  for  the  storage  of  ad- 
dresses,.They  are  also  often  called  data  counters  or  pointers.  They  are 
double  registers,  i.e..  two  eight-bit  registers.  Their  essential 
characteristic  is  to  be  connected  to  the  address  bus.  The  address 
registers  create  the  address  bus.  The  address  bus  appears  on  the  left  and 
the  bottom  part  of  the  illustration  in  Figure  2.4. 
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The  onJy  way  to  load  the  contents  of  these  16-bit  registers  is  via  the 
data  bus.  Two  transfers  will  be  necessary  along  the  data  bus  in  order  to 
transfer  16  bits.  In  order  to  differentiate  between  the  lower  half  and  the 
higher  half  of  each  register,  they  are  usually  labelled  as  L  (low)  or  H 
(high),  denoting  bits  0  through  7,  and  8  through  15  respectively.  This 
label  is  used  whenever  it  is  necessary  to  differentiate  the  halves  of  these 
registers.  At  least  two  address  registers  are  present  within  most 
microprocessors.  "MUX"  in  Fig.  2.4  stands  for  multiplexer. 


DATA  BUS  (8} 


MUX 


INDEX  f  REC 

ISTER 

STACK  i  POINTER 
 (  

PROGRAM  '  COUNTER 

1  MUX 

16-BIT 

ADDRESS  REGISTERS 


ADDRESS  BUS  (16) 


Fig.  2.4:  The  16-bit  Address  Registers  Creaie  the  Address  Bus 


Program  Counter  (PC) 

The  program  counter  must  be  present  in  any  processor.  It  contams 
the  address  of  the  next  instruction  to  be  executed.  The  presence  of  the 
program  counter  is  indispensable  and  fundamental  to  program  execu- 
tion. The  mechanism  of  program  execution  and  the  automatic  sequenc- 
ing implemented  with  the  program  counter  will  be  described  in  the  next 
section.  Briefly,  execution  of  a  program  is  normally  sequential.  In 
order  to  access  the  next  instruction,  it  is  necessary  to  bring  it  from  the 
memory  Into  the  microprocessor.  The  contents  of  the  PC  will  be 
deposited  on  the  address  bus,  and  transmuted  towards  the  memory. 
The  memory  will  then  read  the  contents  specified  by  this  address  and 
send  back  the  corresponding  word  to  the  MPU,  This  is  the  instruction. 
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In  a  few  exceptional  microprocessors,  such  as  the  two-chip  F8,  there  is 
no  PC  on  the  microprocessor.  This  does  not  mean  that  the  system  does 
not  have  a  program  counter.  The  PC  happens  to  be  implemented  direct- 
ly on  the  memory  chip,  for  reasons  of  efficiency. 

Stack  Pointer  (SP) 

The  stack  has  not  been  introduced  yet  and  will  be  described  in  the 
next  section.  In  most  powerful,  general-purpose  microprocessors,  the 
stack  is  implemented  in  "software,"  i.e.,  within  the  memory.  In  order 
to  keep  track  of  the  top  of  this  stack  within  the  memory,  a  i6-bit 
register  is  dedicated  to  the  stack  pointer  or  SP.  The  SP  contains  the  ad- 
dress of  the  top  of  the  stack  within  the  memory.  It  will  be  shown  that 
the  stack  is  indispensable  for  interrupts  and  for  subroutines. 

Index  Register  (IX) 

Indexing  is  a  memory-addressing  facility  which  is  not  always  pro- 
vided in  microprocessors.  The  various  memory-addressing  techniques 
will  be  described  in  Chapter  5.  Indexing  is  a  facility  for  accessing  blocks 
of  data  in  the  memory  with  a  single  instruction.  An  index  register  will 
typically  contain  a  displacement  which  will  be  automatically  added  to  a 
base  (or  it  might  contain  a  base  which  would  be  added  to  a  displace- 
ment). In  short,  indexing  is  used  to  access  any  word  within  a  block  of 
data. 

The  Stack 

A  stack  is  formally  called  an  LIFO  structure  {last-in,  first-out).  A 
stack  is  a  set  of  registers,  or  memory  locations,  allocated  to  this  data 
structure.  The  essential  characteristic  of  this  structure  is  that  it  is  a 
chronological  structure.  The  first  element  introduced  into  the  stack  is 
always  at  the  bottom  of  the  stack.  The  element  most  recently  deposited 
in  the  stack  is  on  the  top  of  the  stack.  The  analogy  can  be  drawn  with  a 
stack  of  plates  on  a  restaurant  counter.  There  is  a  hole  in  the  counter 
with  a  spring  in  the  bottom.  Plates  are  piled  up  in  the  hole.  With  this 
organization,  it  is  guaranteed  that  the  plate  which  has  been  put  first  in 
the  stack  (the  oldest)  Is  always  at  the  bottom.  The  one  that  has  been 
placed  most  recently  on  the  stack  is  the  one  which  is  on  top  of  it.  This 
example  also  illustrates  another  characteristic  of  the  stack.  In  normal 
use,  a  stack  is  only  accessible  via  two  instructions:  "push"  and  "pop" 
(or  "pull").  The  push  operation  results  in  depositing  one  element  on 
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top  of  the  stack  (two  in  the  case  of  the  Z80).  The  pull  operation  consists 
of  removing  one  element  from  the  stack.  In  the  case  of  a 
microprocessor,  it  is  the  accumulator  that  wili  be  deposited  on  top  of 
the  stack.  The  pop  will  result  in  a  transfer  of  the  top  element  of  the 
stack  into  the  accumulator.  Other  specialized  instructions  may  exist  to 
transfer  the  top  of  the  stack  between  other  specialized  registers,  such  as 
the  status  register.  The  Z80  is  more  versatile  than  most  in  this  respect. 

The  availability  of  a  stack  is  required  to  implement  three  program- 
ming facilities  withm  the  computer  system;  subroutines,  interrupts,  and 
temporary  data  storage.  The  role  of  the  stack  during  subroutines  will  be 
explained  in  Chapter  3  (Basic  Programming  Techniques).  The  role  of 
the  stack  during  interrupts  will  be  explained  m  Chapter  6  (Input/Out- 
put Techniques).  Finally,  the  role  of  the  stack  m  saving  data  at  high 
speed  will  be  explained  during  specific  application  programs. 

We  will  simply  assume  at  this  point  that  the  stack  is  a  required  facility 
m  every  computer  system.  A  stack  may  be  implemented  in  two  ways: 

1.  A  fixed  number  of  registers  may  be  provided  within  the  micro- 
processor itself.  This  is  a  "hardware  stack."  It  has  the  advantage  of 
high  speed.  However,  it  has  the  disadvantage  of  a  limited  number  of 
registers. 

2.  Most  general-purpose  microprocessors  choose  another  approach, 
the  software  stack,  m  order  not  to  restrict  the  stack  to  a  very  small 
number  of  registers.  This  is  the  approach  chosen  in  the  Z80.  In  the  soft- 
ware approach,  a  dedicated  register  within  the  microprocessor,  here 
register  SP,  stores  the  stack  pointer,  i.e.,  the  address  of  the  top  element 
of  the  stack  {or,  sometimes,  the  address  of  the  top  element  of  the  stack 
plus  one).  The  stack  is  then  implemented  as  an  area  of  memory.  The 
stack  pointer  will  therefore  require  16  bits  to  point  anywhere  in  the 
memory. 
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Fig,  2.5:  The  Two-Stack  Manipuiation  Instructions 
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The  Instruction  Execution  Cycle 

Let  us  refer  now  to  Figure  2.6.  The  microprocessor  unit  appears  on 
the  left,  and  the  memory  appears  on  the  right.  The  memory  chip  may  be 
a  ROM  or  a  RAM,  or  any  other  chip  which  happens  to  contain 
memory.  The  memory  is  used  to  store  instructions  and  data.  Here,  we 
will  fetch  one  instruction  from  the  memory  to  illustrate  the  role  of  the 
program  counter.  We  assume  that  the  program  counter  has  valid  con- 
tents. It  now  holds  a  16-bit  address  which  is  the  address  of  the  next  in- 
struction to  fetch  m  the  memory.  Every  processor  proceeds  in  three 
cycles; 

1 —  fetch  the  next  mstruction 

2 —  decode  the  instruction 

3 —  execute  the  mstruction 


Fetch 

Let  us  now  follow  the  sequence.  In  the  first  cycle,  the  contents  of  the 
program  counter  are  deposited  on  the  address  bus  and  gated  to  the 
memory  (on  the  address  bus).  Simultaneously,  a  read  signal  may  be 
issued  on  the  control  bus  of  the  system,  if  required.  The  memory  will 
receive  the  address.  This  address  is  used  to  specify  one  location  within 
the  memory.  Upon  receiving  the  read  signal,  the  memory  will  decode 
the  address  it  has  received,  through  internal  decoders,  and  will  select 
the  location  specified  by  the  address.  A  few  hundred  nanoseconds  later, 
the  memory  will  deposit  the  eight-bit  data  corresponding  to  the 
specified  address  on  its  data  bus.  This  eight-bit  word  is  the  instruction 
that  we  want  to  fetch.  In  our  illustration,  this  instruction  will  be 
deposited  the  data  bus  on  top  of  the  MPU  box. 

Let  us  briefly  summarize  the  sequencing;  the  contents  of  the  program 
counter  are  output  on  the  address  bus.  A  read  signal  is  generated.  The 
memory  cycles,  and  perhaps  300  nanoseconds  later,  the  instruction  at 
the  specified  address  is  deposited  on  the  data  bus  (assuming  a  single 
byte  instruction).  The  microprocessor  then  reads  the  data  bus  and 
deposits  its  contents  into  a  specialized  internal  register,  the  IR  register. 
The  IR  is  the  instruction  register:  it  is  eight-bits  wide  and  is  used  to  con- 
tain the  instruction  just  fetched  from  the  memory.  The  fetch  cycle  is 
now  completed.  The  8  bits  of  the  mstruction  are  now  physically  in  the 
special  internal  register  of  the  MPU,  the  IR  register.  The  IR  appears  on 
the  left  of  Figure  2.7.  It  is  not  accessible  to  the  programmer. 
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Fig.  2.6;  Fetching  an  Instruction  from  the  Memory 


Decoding  and  Execution 

Once  the  instruction  is  contained  in  IR,  the  control  unit  of  the 
microprocessor  will  decode  the  contents  and  wilt  be  able  to  generate  the 
correct  sequence  of  internal  and  external  signals  for  the  execution  of  the 
specified  instruction.  There  is,  therefore,  a  short  decoding  delay  fol- 
lowed by  an  execution  phase,  the  length  of  which  depends  on  the  nature 
of  the  instruction  specified.  Some  instructions  will  execute  entirely 
within  the  MPU.  Other  instructions  will  fetch  or  deposit  data  from  or 
into  the  memory.  This  is  why  the  various  instructions  of  the  MPU  re- 
quire various  lengths  of  time  to  execute.  This  duration  is  expressed  as  a 
number  of  (clock)  cycles.  Refer  to  Chapter  4  for  the  number  of 


Fig.  2.7:  Automatic  Sequencing 
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cycles  required  by  each  instruction.  Since  various  clock  rates  may  be 
used,  speed  of  execution  is  normally  expressed  in  number  of  cycles 
rather  than  in  number  of  nanoseconds. 
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Fig.  2.8:  Single-Bus  Architecture 


Fetching  the  Next  Instruction 

We  have  described  how,  using  the  program  counter,  an  mstruction 
can  be  fetched  from  the  memory.  During  the  execution  of  a  program, 
instructions  are  fetched  in  sequence  from  the  memory.  An  automatic 
mechanism  must  therefore  be  provided  to  fetch  mstructions  in  se- 
quence. This  task  is  performed  by  a  simple  incrementer  attached  to  the 
program  counter.  This  is  illustrated  in  Figure  2.7,  Every  time  that  the 
contents  of  the  program  counter  (at  the  bottom  of  the  illustration)  are 
placed  on  the  address  bus,  its  contents  will  be  incremented  and  written 
back  into  the  program  counter.  As  an  example,  if  the  program  counter 
contained  the  value  "0" ,  the  value  "0"  would  be  output  on  the  address 
bus.  Then  the  contents  of  the  program  counter  would  be  incremented 
and  the  value  "1"  would  be  written  back  into  the  program  counter.  In 
this  way,  the  next  time  that  the  program  counter  is  used,  it  is  the  in- 
struction at  address  1  that  will  be  fetched.  We  have  just  implemented  an 
automatic  mechanism  for  sequencing  instructions. 

It  must  be  stressed  that  the  above  descriptions  are  simplified.  In  reali- 
ty, some  instructions  may  be  two-  or  even  three-bytes  long,  so  that  suc- 
cessive bytes  will  be  fetched  in  this  manner  from  the  memory.  However, 
the  mechanism  is  identical.  The  program  counter  !s  used  to  fetch 
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successive  bytes  of  an  instruction  as  well  as  to  fetch  successive  instruc- 
tions themselves.  The  program  counter,  together  with  its  incrementer, 
provides  an  automatic  mechanism  for  pointing  to  successive  memory 
locations. 
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Fig.  2,9:  Execution  of  an  Addition— RO  into  ACC 
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Fig,  2.10:  Addition— Second  Register  Rl  into  ALU 
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We  will  now  execute  an  instruction  within  the  MPU  (see  Figure  2.8). 
A  typical  instruction  will  be,  for  example:  RO  =  RO  +  Rl.  This  means: 
"ADD  the  contents  of  RO  and  RI,  and  store  the  results  in  RO."  To  per- 
form this  operation,  the  contents  of  RO  will  be  read  from  register  RO, 
earned  via  the  single  bus  to  the  left  input  of  the  ALU,  and  stored  in  the 
buffer  register  there.  RI  will  then  be  selected  and  its  contents  will  be 
read  onto  the  bus,  then  transferred  to  the  right  input  of  the  ALU.  This 
sequence  is  illustrated  in  Figures  2.9  and  2.10.  At  this  point, 
the  right  input  of  the  ALU  is  conditioned  by  Rl,  and  the  left 
input  of  the  ALU  is  conditioned  by  the  buffer  register,  containing  the 
previous  value  of  RO.  The  operation  can  be  performed.  The  addition  is 
performed  by  the  ALU,  and  the  results  appear  on  the  ALU  output,  in 
the  lower  right-hand  corner  of  Fig.  2.1 1.  The  results  will  be  deposited 
on  the  single  bus,  and  will  be  propagated  back  to  RO.  This  means,  in 
practice,  that  the  input  latch  of  RO  will  be  enabled,  so  that  data  can  be 
written  into  it.  Execution  of  the  instruction  is  now  complete.  The 
results  of  the  addition  are  in  RO,  It  should  be  noted  that  the  contents  of 
RI  have  not  been  modified  by  this  operation.  This  is  a  general  prin- 
ciple: the  contents  of  a  register,  or  of  any  read/write  memory,  are  not 
modified  by  a  read  operation. 

The  buffer  register  on  the  left  input  of  the  ALU  was  necessary  in 
order  lo  memorize  the  contents  of  RO,  so  that  the  single  bus  could  be 
used  again  for  another  transfer.  However,  a  problem  remains. 


Fig.  2.11;  Result  is  Generated  and  Goes  Into  RO 
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The  CrUical  Race  Problem 

The  simple  organization  shown  in  Figure  2.8  will  not  function  cor- 
rectly. 

Question:  What  is  the  timing  problem? 

Answer:  The  problem  is  that  the  result  which  will  be  propagated  out 
of  the  ALU  will  be  deposited  back  on  the  single  bus.  It  will  not  pro- 
pagate just  in  the  direction  of  RO,  but  along  all  of  the  bus.  In  particular, 
it  will  recondition  the  right  input  of  the  ALU,  changing  the  result  coming 
out  of  it  a  few  nanoseconds  later.  This  is  a  critical  race.  The  output  of 
the  ALU  must  be  isolated  from  its  input  (see  Figure  2.12). 

Several  solutions  are  possible  which  will  isolate  the  input  of  the  ALU 
from  the  output.  A  buffer  register  must  be  used.  The  buffer  register 
could  be  placed  on  the  output  of  the  ALU,  or  on  its  input.  It  is  usually 
placed  on  the  input  of  the  ALU.  Here  it  would  be  placed  on  its  right  in- 
put. The  buffering  of  the  system  is  now  sufficient  for  a  correct  opera- 
tion. It  will  be  shown  later  in  this  chapter  that  if  the  left  register  which 
appears  in  this  illustration  is  to  be  used  as  an  accumulator  (permitting 
the  use  of  one-byte  long  instructions),  then  the  accumulator  will  require 
a  buffer  too,  as  shown  in  Figure  2.13. 


Fig.  2.12:  The  Critical  Race  Problem 
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Fig.  2.13:  Two  Buffers  Are  Required  (Temp  Registers) 


INTERNAL  ORGANIZATION  OF  THE  Z80 

The  terms  necessary  in  order  to  understand  the  internai  elements  of 
the  microprocessor  have  been  defined.  We  will  now  examine  in  more 
detail  the  Z80  itself,  and  describe  its  capabilities.  The  internal  organiza- 
tion of  the  Z80  is  shown  in  Figure  2. 14.  This  diagram  presents  a  logical 
description  of  the  device.  Additional  interconnections  may  exist  but  are 
not  shown.  Let  us  examine  the  diagram  from  right  to  left. 

On  the  right  part  of  the  illustration,  the  arithmetic-logical  unit  {the 
ALU)  may  be  recognized  by  its  characteristic  "V"  shape.  The  accumu- 
lator register,  which  has  been  described  in  the  previous  section,  is  iden- 
tified as  A  on  the  right  input  path  of  the  ALU.  It  has  been  shown  in  the 
previous  section  that  the  accumulator  should  be  equipped  with  a  buffer 
register.  This  is  the  register  labeled  ACT  (temporary  accumulator). 
Here,  the  left  input  of  the  ALU  is  also  equipped  with  a  temporary 
register,  called  TMP.  The  operation  of  the  ALU  will  become  clear  in  the 
next  section,  where  we  will  describe  the  execution  of  actual  instructions. 
The  flags  register  is.ca.llsd"¥"inlhe  Z80,and  is  shown  on  the  right  of  the 
accumulator  register.  The  contents  of  the  flags  register  are  essentially 
conditioned  by  the  ALU,  but  it  will  be  shown  that  some  of  its  bits  may 
also  be  conditioned  by  other  modules  or  events. 

The  accumulator  and  the  flags  registers  are  shown  as  double  registers 
labelled  respectively  A,  A'  and  F,  F'.  This  is  because  the  Z80  is 
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equipped  internally  with  two  sets  of  registers:  A  +  F,  and  A'  +  F'. 
However,  only  o/te  set  of  these  registers  may  be  used  at  any  one  time.  A 
special  instruction  is  provided  to  exchange  the  contents  of  A  and  F  with 
A'  and  F',  In  order  to  simplify  the  explanations,  only  A  and  F  will  be 
shown  on  most  of  the  diagrams  which  foliow.  The  reader  should 
remember  that  he  has  the  option  of  switching  to  the  alternate  register 
set  A'  and  F'  if  desired. 

The  role  of  each  flag  in  the  flags  register  will  be  described  in  Chapter 
3  (Basic  Programming  Techniques*. 

A  large  block  of  registers  is  shown  at  the  center  of  the  illustration.  On 
top  of  the  block  of  registers,  two  identical  groups  can  be  recognized. 
Each  one  includes  six  registers  labeled  B,  C,  D,  E,  H,  L.  These  are  the 
general-purpose  eight-bt!  registers  of  the  Z80.  There  are  two  peculiari- 
ties of  the  Z80  with  respect  to  the  standard  microprocessor  which  has 
been  described  at  the  beginning  of  this  chapter. 

First,  the  Z80  is  equipped  with  [wo  banks  of  registers,  i.e.,  two  iden- 
tical groups  of  6  registers.  Only  six  registers  may  be  used  at  any  one 
time.  However,  special  instructions  are  provided  to  switch  between  the 
two  banks  of  registers.  One  bank,  therefore,  behaves  as  an  internai 
memory,  while  the  other  one  behaves  as  a  working  set  of  internal 
registers.  The  possible  uses  of  this  special  facility  will  be  described  in 
the  next  chapter. 

Conceptually,  it  will  be  assumed,  for  the  time  being,  that  there  are 
only  six  working  registers,  B,  C,  D,  E,  H,  and  L,  and  the  second 
register  bank  will  temporarily  be  ignored,  in  order  to  avoid  confusion. 

The  MUX  symbol  which  appears  above  the  memory  bank  is  an  ab- 
breviation for  multiplexer.  The  data  coming  from  the  internal  data  bus 
will  be  gated  through  the  multiplexer  to  the  selected  register.  However, 
only  one  of  these  registers  can  be  connected  to  the  interna!  data  bus  at 
any  one  time. 

A  second  characteristic  of  these  six  registers,  in  addition  to  being 
general-purpose  eight-bit  registers,  is  that  they  are  equipped  with  a  con- 
nection to  the  address  bus.  This  is  why  they  have  been  grouped  m 
pairs.  For  example,  the  contents  of  B  and  C  can  be  gated  simultaneous- 
ly onto  the  I6-bit  address  bus  which  appears  at  the  bottom  of  the  illustra- 
tion. As  a  result,  this  group  of  6  registers  may  be  used  to  store  either 
eight-bit  data  or  else  J  6-bit  pointers  for  memory  addressing. 

The  third  group  of  registers,  which  appears  below  the  two  previous 
ones  in  the  middle  of  Figure  2.14,  contains  four  "pure"  address 
registers.  As  in  any  microprocessor,  we  find  the  program  counter  (PC) 
and  the  stack  pointer  (SP).  Recall  that  the  program  counter  contains 
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the  address  of  the  next  instruction  to  be  executed. 

The  stack  pointer  points  to  the  top  of  the  stack  in  the  memory.  In  the 
case  of  the  Z80,  the  stack  pointer  points  to  the  last  actual  entry  m  the 
stack.  (In  other  microprocessors,  the  stack  pomter  points  just  above  the 
last  entry.)  Also,  the  stack  grows  "downwards,  "i.e.  towards  the  lower 
addresses. 

This  means  that  the  stack  pointer  must  be  decremented  any  time  a 
new  word  is  pushed  on  the  stack.  Conversely,  whenever  a  word  is 
removed  (popped)  from  the  stack,  the  stack  pointer  must  be  m- 
cremented  by  one.  In  the  case  of  the  Z80,  the  "push"  and  "pop" 
always  involve  two  words  at  the  same  time,  so  that  the  contents  of  the 
stack  pomter  will  be  decremented  or  incremented  by  two. 

Looking  at  the  remaining  two  registers  of  this  group  of  four  registers, 
we  find  a  new  type  of  register  which  has  not  been  described  yet:  two 
mdex-registers,  labeled  IX  (Index  Register  X)  and  lY  (Index  Register 
Y).  These  two  registers  are  equipped  with  a  special  adder  shown  as  a 
miniature  V-shaped  ALU  on  the  right  of  these  registers  in  Figure  2.14. 
A  byte  brought  along  the  internal  data  bus  may  be  added  to  the  con- 
tents of  IX  or  1 Y.  This  byte  is  called  the  displacement,  when  using  an  in- 
dexed instruction.  Special  instructions  are  provided  which  will 
automatically  add  this  displacement  to  the  contents  of  IX  or  lY  and 
generate  an  address.  This  is  called  mdexmg.  It  allows  convenient  access 
to  any  sequential  block  of  data.  This  important  facility  will  be  des- 
cribed in  Chapter  5  on  addressmg  techniques. 

Finally,  a  special  box  labeled  "  ±  i "  appears  below  and  to  the  left  of  the 
block  of  registers.  This  is  an  increment/ decrement.  The  contents  of  any 
of  the  register  pairs  SP,  PC,  BC,  DE,  HL  (the  "pure  address"  registers) 
may  be  automatically  incremented  or  decremented  every  time  they  depos- 
it an  address  on  the  internal  address  bus.  This  is  an  essential  facility  for 
implementing  automated  program  loops  which  will  be  described  in  the 
next  section.  Using  this  feature  it  will  be  possible  to  access  successive 
memory  locations  conveniently. 

Let  us  move  now  to  the  left  of  the  illustration.  One  register  pair  is 
shown,  isolated  on  the  left:  I  and  R.  The  I  register  is  called  the  mterrupt- 
page  address  register.  Its  role  will  be  described  in  the  section  on  inter- 
rupts of  Chapter  6  (Input/Output  Techniques).  It  is  used  only  in  a 
special  mode  where  an  indirect  call  to  a  memory  location  is  generated  in 
response  to  an  interrupt.  The  I  register  is  used  to  store  the  high-order 
part  of  the  indirect  address.  The  lower  part  of  the  address  is  supplied  by 
the  device  which  generated  the  interrupt. 
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The  R  register  is  the  memory-refresh  register.  It  is  provided  to  refresh 
dynamic  memories  automatically.  Such  a  register  has  traditionally  been 
located  outside  the  microprocessor,  since  it  is  associated  with  the 
dynamic  memory.  It  is  a  convenient  feature  which  minimizes  the 
amount  of  external  hardware  for  some  types  of  dynamic  memories.  It  will 
not  be  used  here  for  any  programming  purposes,  as  it  is  essentially  a 
hardware  feature  (see  reference  C207  "Microprocessor  Interfacing 
Techniques"  for  a  detailed  description  of  memory  refresh  techniques). 
However,  it  is  possible  to  use  it  as  a  software  cloclt,  for  example. 

Let  us  move  now  to  the  far  left  of  the  illustration.  There  the  control 
section  of  the  microprocessor  is  located.  From  top  to  bottom,  we  find 
first  the  instruction  register  IR,  which  will  contain  the  instruction  to  be 
executed.  The  IR  register  is  totally  distinct  from  the  "I,  R"  register  pair 
described  above.  The  instruction  is  received  from  the  memory  via  the 
data  bus,  is  transmitted  along  the  internal  data  bus  and  is  finally 
deposited  into  the  instruction  register.  Below  the  instruction  register  ap- 
pears the  decoder  which  will  send  signals  to  the  controller-sequencer 
and  cause  the  execution  of  the  instruction  within  the  microprocessor 
and  outside  it.  The  control  section  generates  and  manages  the  control 
bus  which  appears  at  the  bottom  part  of  the  illustration. 

The  three  buses  managed  or  generated  by  the  system,  i.e.,  the  data 
bus,  the  address  bus,  and  the  control  bus,  propagate  outside  the 
microprocessor  through  its  pins.  The  external  connections  are  shown 
on  the  right-most  part  of  the  illustration.  The  buses  are  isolated  from 
the  outside  through  buffers  shown  in  Figure  2. 14. 

All  the  logical  elements  of  the  Z80  have  now  been  described.  It  is  not 
essential  to  understand  the  detailed  operation  of  the  Z80  in  order  to 
start  writing  programs.  However,  for  the  programmer  who  wishes  to 
write  efficient  codes,  the  speed  of  a  program  and  its  size  will  depend 
upon  the  correct  choice  of  registers  as  well  as  the  correct  choice  of 
techniques.  To  make  a  correct  choice,  it  is  necessary  to  understand  how 
instructions  are  executed  within  the  microprocessor.  We  will  therefore 
examine  here  the  execution  of  typical  instructions  inside  the  280  to 
demonstrate  the  role  and  use  of  the  internal  registers  and  buses. 
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INSTRUCTION  FORMATS 

The  ZSO  instructions  are  listed  in  Chapter  4.  Z80  instructions  may 
be  formated  in  one,  two,  three  or  four  bytes.  An  instruction  specifies 
the  operation  to  be  performed  by  the  microprocessor.  From  a 
simpiified  standpoint,  every  instruction  may  be  represented  as  an  op- 
code followed  by  an  optionai  literal  or  address  field,  comprising  one  or 
two  words.  The  opcode  field  specifies  the  operation  to  be  carried  out. 
In  strict  computer  terminology,  the  opcode  represents  only  those  bits 
which  specify  the  operation  to  be  performed,  exclusive  of  the  register 
pointers  that  might  be  necessary.  In  the  microprocessor  world,  it  is  con- 
venient to  call  opcode  the  operation  code  itself,  as  well  as  any  register 
pointers  which  it  might  incorporate.  This  "generalized  opcode"  must 
reside  m  an  eight-bit  word  for  efficiency  (this  is  the  limiting  factor  on 
the  number  of  instructions  available  in  a  microprocessor). 

The  8080  uses  instructions  which  may  be  one,  two,  three,  bytes  long 
(see  Figure  2. 15).  However,  the  ZSO  is  equipped  with  additional  indexed 
instructions,  which  require  one  more  byte.  In  the  case  of  the  ZSO,  op- 
codes are,  in  general,  one  byte  long,  except  for  special  instructions 
which  require  a  two-byte  opcode. 

Some  instructions  require  that  one  byte  of  data  follow  the  opcode,  in 
such  a  case,  the  instruction  vvil!  be  a  two-byte  instruction,  the  second 
byte  of  which  is  data  {except  for  indexing,  which  adds  an  extra  byte). 

In  other  cases,  the  instruction  might  require  the  specification  of  an 
address.  An  address  requires  16  bits  and,  therefore,  two  bytes.  In  that 
case,  the  instruction  will  be  a  three-byte  or  a  four-byte  instruction. 

For  each  byte  of  the  instruction,  the  control  unit  will  have  to  perform 
a  memory  fetch,  which  will  require  four  clock  cycles.  The  shorter  the 
instruction,  the  faster  the  execution. 

A  One-Word  Instruction 

One-word  instructions  are,  in  principle,  fastest  and  are  favored  by 
the  programmer,  A  typical  such  instruction  for  the  ZSO  is; 

LD  r,  r= 

This  instruction  means:  "Transfer  the  contents  of  register  r'  into  r," 
This  is  a  typical  "register-to-register"  operation.  Every  microprocessor 
must  be  equipped  with  such  instructions,  which  allow  the  programmer 
to  transfer  information  from  any  of  the  machine's  registers  into 
another  one.  Instructions  referencing  special  registers  of  the  machine. 
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Fig.  2.15  Typical  Instruction  Formats 


such  as  the  accumulator  or  other  special-purpose  registers,  may  have  a 
special  opcode. 

After  execution  of  the  above  instruction,  the  contents  of  r  vifill  be 
equal  to  the  contents  of  r'.  The  contents  of  r'  will  not  have  been 
modified  by  the  read  operation. 

Every  instruction  must  be  represented  internally  in  a  binary  format. 
The  above  representation  "LD  r,r'  "  is  symbolic  or  mnemonic.  It  is 
called  the  assembly-language  representation  of  an  instruction.  It  is 
simply  meant  as  a  convenient  symbolic  representation  of  the  actual 
binary  encoding  for  that  instruction.  The  binary  code  which  will  repre- 
sent this  instruction  inside  the  memory  is:  0  I  D  D  D  S  S  S  (bits  0  to  7). 

This  representation  is  still  partially  symbolic.  Each  of  the  letters  S 
and  D  stands  for  a  binary  bit.  The  three  D's,  "D  D  D",  represent  the 
three  bits  pointing  to  the  destination  register.  Three  bits  allow  selection 
of  one  out  of  eight  possible  registers.  The  codes  for  these  registers  ap- 
pear in  Figure  2.16.  For  example,  the  code  for  register  B  is  "0  0  0",  the 
code  for  register  C  is  "0  0  I",  and  so  on. 

Similarly,  "S  S  S"  represents  the  three  bits  pointing  to  the  source 
register.  The  convention  here  is  that  register  r'  is  the  source,  and  that 
register  r  is  the  destination.  The  placement  of  the  bits  in  the  binary 
representation  of  an  instruction  is  not  meant  for  the  convenience  of  the 
programmer,  but  for  the  convenience  of  the  control  section  of  the 
microprocessor,  which  must  decode  and  execute  the  instruction.  The 
assembly-language  representation,  however,  is  meant  for  the  conve- 
nience of  the  programmer.  It  could  be  argued  that  LD  r,r'  should  really 
mean:  "Transfer  contents  of  r  into  r',"  However,  the  convention  has 
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been  chosen  m  order  to  maintain  compatibility  with  the  binary 
representation  in  this  case.  It  is  naturally  arbitrary. 

Exercise 2.1:  Write  below  the  binary  code  which  wili  transfer  the  con- 
tents of  register  C  into  register  B.  Consult  Fig.  2.16  for  the  codes  cor- 
responding to  C  and  B. 

Another  simple  example  of  a  one-word  mstruction  is: 

ADD  A,  r 

This  instruction  will  result  in  adding  the  contents  of  a  specified 
register  (r)  to  the  accumulator  (A).  Symbolically,  this  operation  may  be 
represented  by;  A  =  A  +  r.  It  can  be  verified  in  Chapter  4  that  the 
binary  representation  of  this  instruction  is: 

1  oooos  s  s 

where  S  S  S  specifies  the  register  to  be  added  to  the  accumulator.  Again, 
the  register  codes  appear  in  Figure  2.16. 

Exercise  2.2:  What  is  the  binary  code  of  the  instruction  which  will  add 
the  contents  of  register  D  to  the  accumulator? 


CODE 

REGISTER 

0  0  0 

B 

0  0  1 

C 

0  1  0 

D 

0  I  i 

E 

1  0  0 

fi 

1  0  1 

L 

1  i  0 

'  (MEflCRY) 

i  1 1 

A 

Fig.  2.16:  The  Register  Codes 


A  Two-Word  Instruction 

ADD  A,  n 

This  simple  two-word  mstruction  will  add  the  contents  of  the  second 
byte  of  the  instruction  to  the  accumulator.  The  contents  of  the  second 
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word  of  the  instruction  are  said  to  be  a  "literal."  They  are  data  and  are 
treated  as  eight  bits  without  any  particular  significance.  They  could 
happen  to  be  a  character  or  numerical  data.  This  is  irrelevant  to  the 
operation.  The  code  for  this  instruction  is: 

1  i  0  0  0  1  i  0  followed  by  the  8-bit  byte  "n" 

This  is  an  immediate  operation.  "Immediate,"  in  most  programming 
languages,  means  that  the  next  word,  or  words,  within  the  instruction 
contams  a  piece  of  data  which  should  not  be  interpreted  (the  way  an  op- 
code is).  It  means  that  the  next  one  or  two  words  are  to  be  treated  as  a 
literal. 

The  control  unit  is  programmed  to  "know"  how  many  words  each 
instruction  has.  It  will,  therefore,  always  fetch  and  execute  the  right 
number  of  words  for  each  instruction.  However,  the  longer  the  possible 
number  of  words  for  the  instruction,  the  more  complex  it  is  for  the  con- 
trol unit  to  decode. 


A  Three-Word  Instruction 

LD  A,  (nn) 

The  mstruction  requires  three  words.  It  means:  "Load  the  ac- 
cumulator from  the  memory  address  specified  in  the  next  two  bytes  of 
the  instruction."  Since  addresses  are  16-bits  long,  they  require  two 
words.  In  binary,  this  instruction  is  represented  by; 

0  0  1  1  i  0  i  0:  I  8  bits  for  the  opcode 

Low  address:  8  bits  for  the  lower  part  of  the  address 

High  address:    |  8  bits  for  the  upper  part  of  the  address 


EXECUTION  OF  INSTRUCTIONS  WITHIN  THE  Z80 

We  have  seen  that  all  instructions  are  executed  in  three  phases: 
FETCH,  DECODE,  EXECUTE.  We  now  need  to  introduce  some 
definitions.  Each  of  these  phases  will  require  several  clock  cycles.  The 
Z80  executes  each  phase  in  one  or  more  logical  cycles,  called  a 
"machine  cycle."  The  shortest  machine  cycle  lasts  three  clock  cycles. 

Accessing  the  memory  requires  three  cycles  for  any  operands,  four 
clock  cycles  for  the  initial  fetch.  Since  each  instruction  must  be  fetched 
first  from  the  memory,  the  fastest  instruction  will  require  four  clock 
cycles.  Most  instructions  will  require  more. 

Each  machine  cycle  is  labeled  as  Ml,  M2,  etc.,  and  will  require  three 
or  more  clock  cycles,  or  "states,"  labeled  Ti,  T2,  etc. 
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The  FETCH  Phase 

The  FETCH  phase  of  an  instruction  is  implemented  during  the  first 
three  states  of  machine  cycle  Ml;  they  are  called  Tl,  T2,  and  T3.  These 
three  states  are  common  to  all  instructions  of  the  microprocessor,  as  all 
instructions  must  be  fetched  prior  to  execution.  The  FETCH 
mechanism  is  the  following: 

Tl  ;  PC  OUT 

The  first  step  is  to  present  the  address  of  the  next  instruction  to  the 
memory.  This  address  is  contained  in  the  program  counter  (PC).  As  the 
first  step  of  any  instruction  fetch,  the  contents  of  the  PC  are  placed  on 
the  address  bus  (see  Figure  2.17).  At  this  point,  an  address  is  presented 
to  the  memory,  and  the  memory  address  decoders  will  decode  this  ad- 
dress in  order  to  select  the  appropriate  location  within  the  memory. 
Several  hundred  ns  (a  nanosecond  is  10''  second)  will  elapse  before  the 
contents  of  the  selected  memory  location  become  available  on  the  out- 
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put  pins  of  the  memory,  which  are  connected  to  the  data  bus.  It  is  standard 
computer  design  to  use  the  memory  read  time  to  perform  an  operation 
withm  the  microprocessor.  This  operation  is  the  incrementation  of  the 
program  counter: 

T2  :  PC  =  PC  4-  1 

While  the  memory  is  reading,  the  contents  of  the  PC  are  incremented 
by  1  (see  Figure  2.18).  At  the  end  of  state  T2,  the  contents  of  the 
memory  are  available  and  can  be  transferred  within  the  micro- 
processor: 

T3  :  INST  into  !R 


Fig  2.18;  PC  Is  Incremented 


The  DECODE  and  EXECUTE  Phases 

During  state  T3,  the  instruction  which  has  been  read  out  of  the 
memory  is  deposited  on  the  data  bus  and  transferred  into  the  instruc- 
tion register  of  the  Z80,  from  which  point  it  is  decoded. 
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Fig.  2.19:  The  Instruction  Arrives  from  the  Memory  into  IR 

It  should  be  noted  that  state  T4  of  Ml  will  always  be  required.  Once 
the  instruction  has  been  deposited  into  IR  during  T3,  it  is  necessary  to 
decode  and  execute  it.  This  will  require  at  least  one  machine  state,  T4. 

A  few  instructions  require  an  extra  state  of  Ml  (state  T5).  It  will  be 
skipped  by  the  processor  for  most  instructions.  Whenever  the  execution 
of  an  instruction  requires  more  than  MI,  i.e.,  Ml,  M2  or  more  cycles, 
the  transition  will  be  directly  from  state  T4  of  Ml  into  state  Tl  of  M2. 
Let  us  examine  an  example.  The  detailed  internal  sequencing  for  each 
example  is  shown  in  the  tables  of  Figure  2.27.  As  these  tables  have  not  been 
released  for  the  Z80,  the  8080  tables  are  used  instead.  They  provide  an  in- 
depth  understanding  of  instruction  execution. 

LDD.C 

This  corresponds  to  MOV  rl,  r2  for  the  8080.  Refer  to  line  1  of  Fig.  2.27. 

By  coincidence,  the  destination  register  in  this  example  happens  to  be 
named  "D",  The  transfer  is  illustrated  in  Figure  2.20. 

This  instruction  has  been  described  in  the  previous  section,  it 
transfers  the  contents  of  register  C,  denoted  by  "C",  into  register  D. 

The  first  three  states  of  cycle  MI  are  used  to  fetch  the  instruction 
from  the  memory.  At  the  end  of  T3,  the  instruction  is  in  IR,  the  In- 
struction Register,  from  which  point  it  can  be  decoded  (see  Figure  2. 19). 

During  T4:  (S  S  S)  >  TMP, 

The  contents  of  C  are  deposited  into  TMP  (See  Figure  2.21). 
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During  T5:  (TMP)  *-  DDD. 
The  contents  of  TMP  are  deposited  into  D.  This  is  shown  in  Figure  2.22. 
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Fig.  2.20:  Transferring  C  into  D 


Fig.  2.21:  The  Contents  of  C  Are  Deposited  into  TMP 
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Fig.  2,22:  The  Contenls  of  TMP  are  Deposited  into  D 


Execution  of  the  instruction  is  now  complete.  The  contents  of 
register  C  have  been  transferred  into  the  specified  destination  register 
D.  This  terminates  execution  of  the  instruction.  The  other  machine 
cycles  M2,  M3,  M4,  and  M5  will  not  be  necessary  and  execution  stops 
with  Ml. 

It  is  possible  to  compute  the  duration  of  this  instruction  easily.  The 
duration  of  every  state  for  the  standard  Z80  is  the  duration  of  the  clock: 
500  ns.  The  duration  of  this  instruction  is  the  duration  of  five  states,  or 
5  X  500  =  2500  ns  =  2,5  us.  With  a  400  ns  clock,  5  x  400  =  2000  ns 
=  2.0  us. 

Question:  ^hy  does  (his  instruction  require  two  states,  T4  and  T5, 
in  order  to  transfer  the  contents  C  into  D,  rather  than  just  one?  It 
transfers  the  contents  of  C  into  TMP,  and  then  the  contents  of  TMP  in- 
to D.  Woiddn  'r  it  be  simpler  to  transfer  the  contenls  of  C  into  D  direct- 
ly within  a  single  slate? 

Answer:  This  is  not  possible  because  of  the  implementation  chosen 
for  the  internal  registers.  All  the  internal  registers  are,  in  fact,  part  of  a 
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single  RAM,  a  read/write  memory  internal  to  the  microprocessor  chip. 
Only  one  word  may  be  addressed  or  selected  at  a  time  within  an  RAM 
(single-port).  For  this  reason,  it  is  not  possible  to  both  read  and  write 
mlo,  or  from,  an  RAM  at  two  different  locations.  Two  RAM  cycles  are 
required.  It  becomes  necessary  first  to  read  the  data  out  of  the  register 
RAM,  and  store  it  in  a  temporary  register,  TMP,  then,  to  write  it  back 
into  the  final  destination  register,  here  D.  This  is  a  design  inadequacy. 
However,  this  limitation  is  common  to  virtually  all  monolithic 
microprocessors.  A  dual-port  RAM  would  be  required  to  solve  the 
problem.  This  limitation  is  not  intrinsic  to  microprocessors  and  it  normally 
does  not  exist  m  the  case  of  bit-slice  devices.  It  is  a  result  of  the  constant 
search  for  logic  density  on  the  chip  and  may  be  eliminated  in  the  future. 

Important  Exercise: 

At  this  point,  it  is  highly  recommended  that  the  user  review  by  him- 
self the  sequencing  of  this  simple  instruction  before  we  proceed  to  more 
complex  ones.  For  this  purpose,  go  back  to  Figure  2. 14.  Assemble  a  few 
small-sized  "symbols"  such  as  matches,  paperclips,  etc.  Then  move  the 
symbols  on  Figure  2,14  to  simulate  the  flow  of  data  from  the  registers 
into  the  buses.  For  example,  deposit  a  symbol  into  PC.  Tl  will  move 
the  symbol  contained  in  PC  out  on  the  address  bus  towards  the 
memory.  Continue  simulated  execution  in  this  fashion  until  you  feel 
comfortable  with  the  transfers  along  the  buses  and  between  the 
registers.  At  this  point,  you  should  be  ready  to  proceed. 

Progressively  more  complex  instructions  will  now  be  studied: 

ADD  A,  r 

This  instruction  means:  "Add  the  contents  of  register  r  (specified  by 
a  binary  code  S  S  S)  to  the  accumulator  (A),  and  deposit  the  result  in 
the  accumulator."  This  is  an  implicit  instruction.  It  is  called  implicit  as 
it  does  not  explicitly  reference  a  second  register.  The  instruction  expli- 
citly refers  only  to  register  r.  It  implies  that  the  other  register  involved 
in  the  operation  is  the  accumulator.  The  accumulator,  when  used  in 
such  an  implicit  instruction,  is  referenced  both  as  source  and  destina- 
tion. Data  will  be  deposited  in  the  accumulator  as  a  result  of  this  addi- 
tion. The  advantage  of  such  an  implicit  instruction  is  that  its  complete 
opcode  is  only  eight  bits  in  length.  It  requires  only  a  three-bit  register 
field  for  the  specification  of  r.  This  is  a  fast  way  to  perform  an  addition 
operation. 

Other  implicit  instructions  exist  in  the  system  which  will  reference 
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other  specialized  registers.  More  complex  examples  of  such  implicit  in- 
structions are,  for  example,  the  PUSH  and  POP  operations,  which  will 
transfer  information  between  the  top  of  the  stack  and  the  accumulator, 
and  will  at  the  same  time  update  the  stack  pointer  (SP),  decrementing  it 
or  incrementing  it.  They  implicitly  manipulate  the  SP  register. 

The  execution  of  the  ADD  A,  r  instruction  will  now  be  examined  in 
detail.  This  instruction  will  require  two  machine  cycles,  Ml  and  M2.  As 
usual,  during  the  first  three  states  of  Ml,  the  instruction  is  fetched  from 
the  memory  and  deposited  m  the  IR  register.  At  the  beginning  of  T4,  it 
is  decoded  and  can  be  executed.  It  will  be  assumed  here  that  register  B  is 
added  to  the  accumulator.  The  code  for  the  instruction  will  then  be: 
1  0  0  0  0  0  0  0  (the  code  for  register  B  is  0  0  0).  The  8080  equivalent  is 
ADD  r. 

T4:  (S  S  S)  >  TMP,  (A)  >  ACT 


Two  transfers  will  be  executed  simultaneously.  First,  the  contents  of 
the  specified  source  register  {here  B)  are  transferred  into  TMP,  i.e.,  to 
the  right  input  of  the  ALU  (see  Fig.  2.23).  At  the  same  time,  the  con- 
tents of  the  accumulator  are  transferred  to  the  temporary  accumulator 
(ACT).  By  inspecting  Fig.  2,23,  you  will  ascertain  that  those  transfers 
can  occur  in  parallel.  They  use  different  paths  within  the  system.  The 
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transfer  from  B  to  TMP  uses  the  interna!  data  bus.  The  transfer  from 
ACT  uses  a  short  internal  path  independent  of  this  data  bus.  In  order  to 
gain  time,  both  transfers  are  done  simultaneousiy.  At  this  point,  both 
the  left  and  the  right  input  of  the  ALU  are  correctly  conditioned.  The 
left  input  of  the  ALU  is  now  conditioned  by  the  accumulator  contents, 
and  the  right  input  of  the  ALU  is  conditioned  by  the  contents  of  register 
B.  We  are  ready  to  perform  the  addition.  We  would  normally  expect  to 
see  the  addition  take  place  during  state  T5  of  Ml.  However,  this  state  is 
simply  not  used.  The  addition  is  not  performed!  We  will  enter  machine 
cycle  M2.  During  state  Tl,  nothing  happens!  It  is  only  in  state  T2  of  M2 
that  the  addition  takes  place  {refer  to  ADD  r  in  Figure  2.27): 

T2  of  M2:  (ACT)  +  (TMP)  A 

The  contents  of  ACT  are  added  to  the  contents  of  TMP,  and  the 
result  is  finally  deposited  in  the  accumulator.  See  Figure  2.24.  The 
operation  is  now  complete. 


Fig.  2.24:  End  of  ADD  r 


Question:  ^hy  was  the  completion  of  the  addition  deferred  until 
state  T2  of  machine  cycle  M2,  rather  than  taking  place  during  state  T5 
of  MI?  (This  is  a  difficult  question,  which  requires  an  understanding  of 
CPU  design.  However,  the  technique  involved  is  fundamental  to  clock- 
synchronous  CPU  design.  Try  to  see  what  happens.) 
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Answer:  This  is  a  standard  design  "trick"  used  in  most  CPU's.  It  is 
called  "fetch/execute  overlap."  The  basic  idea  is  the  following;  looking 
back  at  Figure  2.23  it  can  be  seen  that  the  actual  execution  of  the  addi- 
tion will  only  require  the  use  of  the  ALU  and  of  the  data  bus.  In  parti- 
cular, it  will  not  access  the  register  RAM  (register  block).  We  (or  the 
control  unit)  know  that  the  next  three  states  which  will  be  executed  after 
completion  of  any  instruction  will  be  Tl,  T2,  T3  of  machine  cycle  Ml 
of  the  next  instruction.  Looking  back  at  the  execution  of  these  three 
states,  it  can  be  seen  that  thetr  execution  will  only  require  access  to  the 
program  counter  (PC)  and  use  of  the  address  bus.  Access  to  the  pro- 
gram counter  will  require  access  to  the  register  RAM,  (This  explains 
why  the  same  trick  could  not  be  used  m  the  instruction  LD  r.r'.j  It  is 
therefore  possible  to  use  simultaneously  the  shaded  area  in  Figure  2.17 
and  the  shaded  area  in  Figure  2.24. 

The  data  bus  is  used  during  state  Tl  of  MI  to  carry  status  informa- 
tion out.  It  cannot  be  used  for  the  addition  that  we  wish  to  perform. 
For  that  reason,  it  becomes  necessary  to  wait  until  state  T2  before  the 
addition  can  be  effectively  carried  out.  This  is  what  occurred  in  the 
chart:  the  addition  is  completed  during  state  T2  of  M2.  The  mechanism 
has  now  been  explained.  The  advantage  of  this  approach  should  now  be 
clear.  Let  us  assume  that  we  had  implemented  a  straightforward 
scheme,  and  performed  the  addition  during  state  T5  of  machine  cycle 
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Tl  1  T2   I  T3    I  Tl 


}-•  FETCH- 
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im 


-EXECUTE- 
Tl  I  T2  I  TJ  i  m 


EXECUTE - 


Fig.  2.25:  FETCH-EXECUTE  Overlap  during  T1-T2 

Ml .  The  duration  of  the  ADD  instruction  would  have  been  5  x  500  = 
2500  ns.  With  the  overlap  approach  which  has  been  implemented,  once 
state  T4  has  been  executed,  the  next  instruction  is  initiated.  In  a  manner 
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that  is  invisible  to  this  next  instruction,  the  **ciever"  control  unit  will 
use  state  T2  to  carry  out  the  end  of  the  addition.  On  the  chart  T2  is 
shown  as  part  of  M2.  Conceptualiy,  M2  will  be  the  second  machine  cy- 
cle of  the  addition.  In  fact,  this  IVI2  will  be  overlapped,  i.e.,  be  identical 
to  machine  cycie  Ml  of  the  next  instruction.  For  the  programmer*  the 
delay  introduced  by  ADD  will  be  only  four  states,  i.e.,  4  x  500  =  2000 
ns,  instead  of  2500  ns  using  the  "straightforward"  approach.  The 
speed  improvement  is  500  ns,  or  20%! 

The  overlap  technique  is  illustrated  on  Figure  2.25.  It  is  used  when- 
ever possible  to  increase  the  apparent  execution  speed  of  the  micropro- 
cessor. Naturally,  it  it  not  possible  to  overlap  in  all  cases.  Required 
buses  or  facilities  must  be  available  without  conflict.  The  control  unit 
* 'knows"  whether  an  overlap  is  possible. 
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Fig.  2.27':  Intel  Instruction  Formats  (continued) 
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Fig.  2.27':  Intel  Instruction  Formats  (continued) 
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Question:  Would  it  be  possible  to  go  further  using  this  scheme,  and 
to  also  use  state  T3ofM2  if  we  have  to  execute  a  longer  instruction  ? 

In  order  to  clarify  the  internal  sequencing  mechanism,  it  is  suggested 
that  you  examine  Figure  2.27,  which  shows  the  detailed  instruction 
execution  for  the  8080.  The  Z80  includes  all  8080  instructions,  and 
more.  The  information  presented  in  Figure  2.27  is  not  available  for  the 
Z80.  It  is  shown  here  for  its  educational  value  in  understanding  the  in- 
ternal operation  of  this  microprocessor.  The  equivalence  between  Z80  and 
8080  instructions  is  shown  in  Appendices  F  and  G. 

A  more  complex  instruction  will  now  be  examined: 
ADD  A,  (HL) 

The  opcode  for  this  instruction  is  10000110.  This  instruction  means 
"add  to  the  accumulator  the  contents  of  memory  location  (HL)."  The 
memory  location  is  specified  through  a  rather  strange  system.  It  is  the 
memory  location  whose  address  is  contained  in  registers  H  and  L,  This 
instruction  assumes  that  these  two  special  registers  (HL)  have  been 
loaded  with  contents  prior  to  executing  the  instruction.  The  16-bit  con- 
tents of  these  registers  will  now  specify  the  address  in  the  memory 
where  data  resides.  This  data  will  be  added  to  the  accumulator,  and  the 
result  will  be  left  in  the  accumulator. 

This  instruction  has  a  history.  It  has  been  supplied  in  order  to  pro- 
vide compatibility  between  the  early  8008,  and  its  successor,  the  8080. 
The  early  8008  was  not  equipped  with  a  direct-memory  addressing 
capability!  The  procedure  used  to  access  the  contents  of  the  memory 
was  to  load  the  two  registers  H  and  L,  and  then  execute  an  instruction 
referencing  H  and  L.  ADD  A,  (HL)  is  just  such  an  instruction.  It  must 
be  stressed  that  the  8080  and  the  Z80  are  not  limited  in  the  same  way  as 
the  8008  in  memory-addressing  capability.  They  do  have  direct-memory 
addressing.  The  facility  for  using  the  H  and  L  registers  becomes  an 
added  advantage,  not  a  drawback,  as  was  the  case  with  the  8008. 

Let  us  now  follow  the  execution  of  this  instruction  (it  is  called 
ADD  M  for  the  8080  and  is  the  16th  instruction  on  Figure  2.27).  States 
Tl,  T2,  and  T3  of  Ml  will  be  used,  as  usual,  to  fetch  the  instruction. 
During  state  T4,  the  contents  of  the  accumulator  are  transferred  to  its 
buffer  register,  ACT,  and  the  left  input  of  the  ALU  is  conditioned. 

Memory  must  be  accessed  in  order  to  provide  the  second  byte  of  data 
which  will  be  added  to  the  accumulator.  The  address  of  this  byte  of 
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data  is  contained  in  H  and  L.  The  contents  of  H  and  L  will  therefore 
have  to  be  transferred  onto  the  address  bus,  where  they  will  be  gated  to 
the  memory.  Let  us  do  it. 


Fig.  2.28:  Transfer  Contents  of  HL  to  Address  Bus 

During  machine  cycle  M2,  we  read:  HL  OUT.  H  and  L  are  deposited  on 
the  address  bus,  in  the  same  way  PC  used  to  be  deposited  there  in 
previous  instructions.  As  a  remark,  it  has  already  been  indicated 
that  during  state  Tl  status  is  output  on  the  data  bus,  but  no  use  of 
this  will  be  made  here.  From  a  simplified  standpoint,  it  will  require  two 
states:  one  for  the  memory  to  read  its  data,  and  one  for  the  data  to 
become  available  and  transferred  onto  the  right  input  of  the  ALU. 
TMP, 

Both  inputs  of  the  ALU  are  now  conditioned.  The  situation  is  analo- 
gous to  the  one  we  were  in  with  the  previous  instruction  ADDA,  r:  both 
inputs  of  the  ALU  are  conditioned.  We  simply  have  to  ADD  as  before, 
A  fetch/execute  overlap  technique  will  be  used,  and,  instead  of  exe- 
cuting the  addition  within  state  T4  of  M2,  final  execution  is  postponed 
until  state  T2  of  M3.  It  can  be  seen  in  Figure  2.27  that  during  T2  we  in- 
deed have:  ACT  +  TMP— *A.  The  addition  is  finally  performed,  the 
contents  of  ACT  are  added  to  TMP,  and  the  result  deposited  into  the 
accumulator  A. 
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Question :  What  is  the  apparent  execution  time  (to  the  programmer)  for 
this  instruction?  Using  a  2.5  Mhz  clock,  is  it  3.6  us?  2,8  us? 

Another  more  complex  instruction  will  now  be  examined  which  is  a 
direct-memory  addressing  instruction  usmg  two  invisible  W  and  Z 
registers: 

LD  A,{nii) 

The  opcode  is  001 1 1010.  The  8080  equivalent  is  LDA  addr.  As  usual, 
states  Tl,  T2,  T3  of  Ml  will  be  used  to  fetch  the  instruction  from  the 
memory.  T4  is  used,  but  no  visible  result  can  be  described.  During  state 
T4,  the  instruction  is  in  fact  decoded.  The  control  unit  then  finds  out 
that  it  has  to  fetch  the  next  two  bytes  of  this  instruction  in  order  to  ob- 
tain the  address  from  which  the  accumulator  will  be  loaded.  The  effect 
of  this  instruction  is  to  load  the  accumulator  from  the  memory  contents 
whose  address  is  specified  in  bytes  2  and  3  of  the  instruction.  Note  that 
state  T4  is  necessary  to  decode  the  instruction.  It  could  be  considered  a 
waste  of  time  since  only  part  of  the  state  is  necessary  to  do  the 
decoding.  It  is.  However,  this  is  the  philosophy  of  clock-synchonous 
logic.  Because  microinstructions  are  used  internally  to  perform  the 
decoding  and  execution,  this  is  the  penalty  that  has  to  be  paid  in  return 
for  the  advantages  of  microprogramming.  The  structure  of  this  instruc- 
tion appears  in  Figure  2.29. 
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Fig.  2.29:  LD  A,  (ADDRESS)  Is  a  3- Word  Instruction 


The  next  two  bytes  of  instruction  will  now  be  fetched.  They  will 
specify  an  address  (see  Figure  2.30). 
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Fig.  2.30:  Before  Execution  of  LD  A 
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Fig.  2.3i:  After  Execution  of  LD  A 


The  effect  of  the  instruction  is  shown  in  Figures  2.30  and  2.31  above. 

Two  special  registers  are  available  to  the  control  unit  withm  the  280 
(but  not  to  the  programmer).  They  are  "W"  and  "Z",  and  are  shown 
in  Figure  2.28. 
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Second  Machine  Cycle  M2:  As  usual,  the  first  2  states.  TI  and  T2,  are 
used  to  fetch  the  contents  of  memory  location  PC.  During  T2,  the  pro- 
gram counter,  PC,  is  incremented.  Sometime  by  the  end  of  T2,  data  be- 
comes available  from  the  memory,  and  appears  on  the  data  bus.  By  the 
end  of  T3,  the  word  which  has  been  fetched  from  memory  address  PC 
(B2,  second  byte  of  the  mstruction)  is  available  on  the  data  bus.  U  must 
now  be  stored  in  a  temporary  register.  It  is  deposited  into  Z:  B2  >  Z 
(see  Figure  2.32). 
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Z80 — ^Z80 


^^^^^^ 


B3 


ADDRESS  DECODER 


MEMORY 


Fig.  2.32:  Second  Byte  of  Instruction  Goes  into  Z 


Machine  Cycle  M3:  Again,  PC  is  deposited  on  the  address  bus,  incre- 
mented, and  finally  the  third  byte,  B3,  is  read  from  the  memory  and  de- 
posited into  register  W  of  the  microprocessor.  At  this  point,  i.e.,  by  the 
end  of  state  T3  of  M3,  registers  W  and  Z  inside  the  microprocessor  con- 
tain B2  and  B3,  i.e.,  the  complete  l6-bit  address  which  was  originally 
contamed  in  the  two  words  following  the  instruction  in  the  memory. 
Execution  can  now  be  completed.  W  and  Z  contain  an  address.  This  ad- 
dress will  have  to  be  sent  to  the  memory,  m  order  to  extract  the  data. 
This  is  done  in  the  next  memory  cycle: 

Machine  Cycle  M4:  This  time,  W  and  Z  are  output  on  the  address  bus. 
The  16-bit  address  is  sent  to  the  memory,  and  by  the  end  of  state  T2, 
data  corresponding  to  the  contents  of  the  specified  memory  location 
becomes  available.  It  is  finally  deposited  in  A  at  the  end  of  state  T3. 
This  terminates  execution  of  this  instruction. 
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This  illustrates  the  use  of  an  immediate  instruction.  This  instruction 
required  three  bytes  in  order  to  store  a  two-byte  explicit  address.  This 
instruction  also  required  four  memory  cycles,  as  it  needed  to  go  to  the 
memory  three  times  in  order  to  extract  the  three  bytes  of  this  three- 
word  instruction,  plus  one  more  memory  access  in  order  to  fetch  the 
data  specified  by  the  address.  It  is  a  long  instruction.  However,  it  is  also 
a  basic  one  for  loading  the  accumulator  with  specified  contents  residing 
at  a  known  memory  location.  It  can  be  noted  that  this  instruction  re- 
quires the  use  of  W  and  Z  registers. 

Question:  Could  this  mst ruction  have  used  other  registers  than  W,  Z 
within  the  system? 

Answer:  No.  If  this  instruction  had  used  other  registers,  for  example 
the  H  and  L  registers,  it  would  have  modified  their  contents.  After  ex- 
ecution of  this  instruction,  the  contents  of  H  and  L  would  have  been 
lost.  It  is  always  assumed  in  a  program  that  an  instruction  will  not 
modify  any  registers  other  than  those  it  is  explicitly  using.  An  instruc- 
tion loading  the  accumulator  should  not  destroy  the  contents  of  any 
other  register.  For  this  reason,  it  becomes  necessary  to  supply  the  extra 
two  registers,  W  and  Z,  for  the  internal  use  of  the  control  unit. 

Question:  Would  it  be  possible  to  use  PC  instead  of  WandZ? 

Answer:  Positively  not.  This  would  be  suicidal.  The  reader  should  ana- 
lyze this. 

One  more  type  of  instruction  will  be  studied  now:  a  branch  or  jump 
instruction,  which  modifies  the  sequence  in  which  instructions  are 
executed  within  the  program.  So  far,  we  have  assumed  that  instructions 
were  executed  sequentially.  Instructions  exist  which  allow  the  pro- 
grammer to  jump  out  of  sequence  to  another  instruction  within  the 
program,  or  in  practical  terms,  to  jump  to  another  area  of  the  memory 
containing  the  program,  or  to  another  address.  One  such  instruction  is: 

JP  nn 

This  instruction  appears  on  Line  18  of  Figure  2.27'  as  "JMP  addr." 
Its  execution  will  be  described  by  following  the  horizontal  line 
of  the  Table.  This  is  again  a  three-word  instruction.  The  first  word 
is  the  opcode,  and  contains  11000011.  The  next  two  words  contain  the 
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16-bit  address,  to  which  the  jump  wili  be  made,  Conceptuaily,  the  ef- 
fect of  this  instruction  is  to  replace  the  contents  of  the  program  counter 
with  the  16  bits  following  the  "JUMP"  opcode.  In  practice,  a  some- 
what different  approach  will  be  implemented,  for  reasons  of  efficiency. 

As  before,  the  first  three  states  of  Ml  correspond  to  the  mstruction- 
fetch.  During  state  T4  the  instruction  is  decoded  and  no  other  event  is 
recorded  (X).  The  next  two  machine  cycles  are  used  to  fetch  bytes  B2 
and  B3  of  the  instruction.  Durmg  M2,  B2  is  fetched  and  deposited  into 
internal  register  Z.  The  next  two  steps  will  be  implemented  by  the  pro- 
cessor during  the  next  instruction- fetch,  as  was  the  case  already  with  the 
addition.  They  will  be  executed  instead  of  the  usual  steps  for  Tl  and  T2 
of  the  next  instruction.  Let  us  iook  at  them. 

The  next  two  steps  will  be:  WZ  OUT  and  (WZ)  -I-  I  >  PC.  In  other 
words,  the  contents  of  WZ  will  be  used  instead  of  the  contents  of  PC 
during  the  next  instruction-fetch.  The  control  unit  will  have  recorded 
the  fact  that  a  jump  was  being  executed  and  will  execute  the  beginning 
of  the  next  instruction  differently. 

The  effect  of  these  two  extra  states  is  the  following: 

The  address  placed  on  the  address  bus  of  the  system  will  be  the  ad- 
dress contained  in  W  and  Z.  In  other  words,  the  next  instruction  will  be 
fetched  from  the  address  that  was  contained  in  W  and  Z.  This  is  effec- 
tively a  jump.  In  addition,  the  contents  of  WZ  will  be  incremented  by  1 
and  deposited  in  the  program  counter,  so  that  the  next  instruction  will 
be  fetched  correctly  by  using  PC  as  usual.  The  effect  is  therefore  cor- 
rect. 

Question:  Why  have  we  not  loaded  the  contents  of  PC  directly?  Why 
use  the  intermediate  Wand  Z  registers? 

Answer:  It  is  not  possible  to  use  PC.  If  we  had  loaded  the  lower  part 
of  PC  (PCL)  with  B2,  instead  of  using  Z,  we  would  have  destroyed  PC! 
It  would  then  have  become  impossible  to  fetch  B3. 

Question:  Would  it  be  possible  to  use  just  Z,  instead  ofW  and  Z? 

Answer:  Yes,  but  it  would  be  slower.  We  could  have  loaded  Z  with 
B2,  then  fetched  B3,  and  deposited  it  into  the  high  order  half  of  PC 
(PCH).  However,  it  would  then  have  become  necessary  to  transfer  Z  in- 
to PCL,  before  using  the  contents  of  PC.  This  would  slow  down  the 
process.  For  this  reason,  both  W  and  Z  should  be  used.  Further,  and  in 
order  to  save  time,  W  and  Z  are  not  transferred  into  PC.  They  are 
directly  gated  to  the  address  bus  in  order  to  fetch  the  next  instruction. 
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Understanding  this  point  is  crucial  to  the  understanding  of  efficient  ex- 
ecution of  instructions  within  the  microprocessor. 

Question:  (For  the  alert  and  informed  reader  only).  What  happens 
in  the  case  of  an  interrupt  at  the  end  of  M3?  (If  instruction  execution  is 
suspended  at  this  point,  the  program  counter  points  to  the  instruction 
following  the  jump,  and  the  jump  address,  contained  in  W  and  Z,  will 
be  lost.) 

The  answer  is  left  as  an  interesting  exercise  for  the  alert  reader. 

The  detailed  descriptions  we  have  presented  for  the  execution  of 
typical  instructions  should  clarify  the  role  of  the  registers  and  of 
the  internal  buses.  A  second  reading  of  the  preceding  section  may 
help  in  gaining  a  detailed  understanding  of  the  internal  operation 
of  the  Z80. 
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 "V  DATA 

\  1/  BUS 


GND 


Fig.  2.33: 


+  5V 

POWER 

280  MPU  Pinout 


The  Z80  Chip 

For  completeness,  the  signals  of  the  Z80  microprocessor  chip  will  be 
examined  here.  It  is  not  indispensable  to  understand  the  functions  of 
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the  Z80  signals  in  order  to  be  able  to  program  it.  The  reader  who  is  not 
interested  in  the  details  of  hardware  may  therefore  skip  this  section. 
The  pinout  of  the  Z80  appears  on  Fig.  2.33.  On  the  right  side  of  the 
illustration,  the  address  bus  and  the  data  bus  perform  their  usual  role, 
as  described  at  the  beginning  of  this  chapter.  We  will  describe  here  the 
function  of  the  signals  on  the  control  bus.  They  are  shown  on  the  left  of 
Figure  2.33. 

The  control  signals  have  been  partitioned  in  four  groups.  They  will 
be  described,  going  from  the  top  of  Figure  2,33  towards  the  bottom. 

The  clock  input  is  4*.  The  Z80  incorporates  the  clock  oscillator  within 
the  microprocessor  chip.  Only  a  330-ohm  pull-up  resistor  is  necessary 
externally.  It  is  connected  to  the  0  input  and  to  5  volts.  However,  at  4 
MHz,  an  external  clock  driver  is  required. 

The  two  bus-control  signals,  BUSRQ  and  BUSAK,  are  used  to  dis- 
connect the  Z80  from  its  busses.  They  are  mainly  used  by  the  DMA,  but 
could  also  be  used  by  another  processor  in  the  system.  BUSRQ  is  the 
bus-request  signal.  It  is  issued  to  the  Z80.  In  response,  the  Z80  will  place 
its  address  bus,  data  bus,  and  tristate  output  control  signals  in  the  high- 
impedance  state,  at  the  end  of  the  current  machine  cycle.  BUSAK  is  the 
acknowledge  signal  issued  by  the  Z80  once  the  busses  have  been  placed 
in  the  high-impedance  state. 

Six  Z80  control  signals  are  related  to  its  internal  status  or  to  its  se- 
quencing: 

INT  and  NMI  are  the  two  interrupt  signals.  INT  is  the  usual  interrupt 
request.  Interrupts  will  be  described  in  Chapter  6.  A  number  of  in- 
put/output devices  may  be  connected  to  the  INT  interrupt  line.  When- 
ever an  interrupt  request  is  present  on  this  line,  and  when  the  internal 
interrupt  enable  flip-flop  (IFF)  is  enabled,  the  Z80  will  accept  the  inter- 
rupt (provided  the  BUSRQ  is  not  active).  It  will  then  generate  an 
acknowledge  signal:  lORQ  (issued  during  the  MI  state).  The  rest  of  the 
sequence  of  events  is  described  m  Chapter  6. 

NMI  is  the  non-maskable  interrupt.  It  is  always  accepted  by  the  Z80, 
and  it  forces  the  Z80  to  jump  to  location  0066  hexadecimal.  It  too  is 
described  in  Chapter  6.  (It  also  assumes  that  BUSRQ  is  not  active.) 

WAIT  is  a  signal  used  to  synchronize  the  Z80  with  slow  memory  or 
input/output  devices.  When  active,  this  signal  indicates  that  the 
memory  or  the  device  is  not  yet  ready  for  the  data  transfer.  The  Z80 
CPU  will  then  enter  a  special  wait  state  until  the  WAIT  signal  becomes 
inactive.  It  will  then  resume  normal  sequencing, 

HALT  is  the  acknowledge  signal  supplied  by  the  Z80  after  it  has  ex- 
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ecuted  the  HALT  instruction.  In  this  state,  the  Z80  waits  for  an  exter- 
nal interrupt  and  keeps  executing  NOPs  to  continually  refresh  memory. 

RESET  is  the  signal  which  usually  initializes  the  MPU.  It  sets  the 
program  counter,  register  I  and  R  to  "0".  It  disables  the  interrupt 
enable  flip-flop  and  sets  the  interrupt  mode  to  "0"=  It  is  normally  used 
after  power  is  applied  to  the  board. 

Memory  and  I/O  Controi 

Six  memory  and  I/O  controi  signals  are  generated  by  the  Z80.  They  are: 
MREQ  is  the  memory  request  signal.  It  indicates  that  the  address  pres- 
ent on  the  address  bus  is  valid.  A  read  or  write  operation  can  then  be 
performed  on  the  memory. 

M 1  is  machine  cycle  1 .  This  cycle  corresponds  to  the  fetch  cycle  of  an 
instruction. 

lORQ  is  the  input/output  request.  It  indicates  that  the  I/O  address 
present  on  bits  0-7  of  the  address  bus  is  valid.  An  I/O  read  or  write 
operation  can  then  be  carried  out,  lORQ  is  also  generated  together  with 
Ml  when  the  Z80  acknowledges  an  interrupt.  This  information  may  be 
used  by  external  chips  to  place  the  interrupt  response  vector  on  the  data 
bus.  (Normal  I/O  operations  never  occur  during  the  MI  state.  The 
combination  lORQ  plus  Ml  indicates  an  interrupt-acknowledge  situa- 
tion.) 

RD  is  the  read  signal.*  It  indicates  the  Z80  is  ready  to  read  the  con- 
tents of  the  data  bus  into  an  internal  register.  It  can  be  used  by  any  ex- 
ternal chip,  whether  memory  or  I/O,  to  deposit  data  onto  the  data  bus. 

WR  is  the  write  signal.*  It  indicates  that  the  data  bus  holds  valid 
data,  ready  to  be  written  into  the  specified  device. 

RFSH  is  the  refresh  signal.  When  RFSH  is  active,  the  lower  seven 
bits  of  the  address  bus  contain  a  refresh  address  for  dynamic  memories. 
The  MREQ  signal  is  then  used  to  perform  the  refresh  by  reading  the 
memory. 

HARDWARE  SUMMARY 

This  completes  our  description  of  the  internal  organization  of  the 
Z80.  The  exact  hardware  details  of  the  Z80  are  not  important  here. 
However,  the  role  of  each  of  the  registers  is  important  and  should  be 
fully  understood  before  proceeding  to  the  next  chapters.  The  actual  in- 
structions available  on  the  Z80  will  now  be  introduced,  and  basic  pro- 
gramming techniques  for  the  Z80  will  be  presented. 

♦used  in  conjunction  with  MREQ  or  lOREQ, 
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BASIC  PROGRAMMING 

TECHNIQUES 

INTRODUCTION 

The  purpose  of  this  chapter  is  to  present  the  basic  techniques  neces- 
sary in  order  to  write  a  program  using  the  Z80.  This  chapter  will  intro- 
duce new  concepts  such  as  register  management,  loops,  and  sub- 
routines. It  will  focus  on  programming  techniques  using  only  the  inter- 
nal Z80  resources,  i.e.,  the  registers.  Actual  programs  will  be  de- 
veloped, such  as  arithmetic  programs.  These  programs  will  serve  to  il- 
lustrate the  various  concepts  presented  so  far  and  will  use  actual  in- 
structions. Thus,  it  will  be  seen  how  instructions  may  be  used  to 
manipulate  the  information  between  the  memory  and  the  MPU,  as  well 
as  to  manipulate  information  within  the  MPU  itself.  The  next  chapter 
will  then  discuss  in  complete  detail  the  instructions  available  on  the  Z80. 
Chapter  5  will  present  Addressing  Techniques,  and  Chapter  6  will  pre- 
sent the  techniques  available  for  manipulatmg  information  outside  the 
Z80;  the  input/Output  Techniques, 

In  this  chapter,  we  will  essentially  learn  by  "doing,"  By  examining 
programs  of  increasing  complexity,  we  will  learn  the  role  of  the  various 
instructions,  of  the  registers,  and  we  will  apply  the  concepts  developed 
so  far.  However,  one  important  concept  will  not  be  presented  here;  it  is 
the  concept  of  addressing  techniques.  Because  of  its  apparent  complexi- 
ty, it  will  be  presented  separately  in  Chapter  5. 

Let  us  immediately  start  writing  some  programs  for  the  Z80,  We  will 
start  with  arithmetic  programs.  The  "programmer's  model"  of  the  Z80 
registers  is  shown  in  Figure  3.0. 
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Fig.  3.0;  The  Z80  Registers 


ARITHMETIC  PROGRAMS 

Arithmetic  programs  include  addition,  subtraction,  muitipiication, 
and  division.  The  programs  presented  here  will  operate  on  integers. 
These  integers  may  be  positive  binary  integers  or  may  be  expressed  in 
two's  complement  notation,  in  which  case  the  left-most  bit  is  the  sign 
bit  (see  Chapter  1  for  a  description  of  the  two's  complement  notation). 

8-Bi(  Addition 

We  will  add  two  8-bit  operands  called  OPl  and  OP2,  respectively 
stored  at  memory  address  ADRI,  and  ADR2.  The  sum  will  be  called 
RES  and  will  be  stored  at  memory  address  ADR3.  This  is  illustrated  in 
Figure  3.1.  The  program  which  will  perform  this  addition  is  the  follow- 
ing: 

Instructions  Comments 

LD    A,  (ADRI)  LOADOPIINTOA 

LD    HL,  (ADR  2)  LOAD  ADDRESS  OF  OP2  INTO  HL 

ADD  A,  (HL)  ADD  0P2  TO  OP  I 

LD    (ADR  3),  A  SAVE  RESULT  RES  AT  ADR3 
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MEMORY 


(FIRST  OPERAND) 


(SECOND  OPERAND) 


(RESULT) 


Fig.  3.1:  Eight-Bit  Addition  RES  =  OPl  +  OP2 

This  is  our  first  program.  The  instructions  are  listed  on  the  left  and 
comments  appear  on  the  right.  Let  us  now  examine  the  program.  It  is  a 
four-instruction  program.  Each  line  is  called  an  instruction  and  is  ex- 
pressed here  in  symbolic  form.  Each  such  instruction  will  be  translated 
by  the  assembler  program  into  one,  two,  three  or  four  binary  bytes.  We 
will  not  concern  ourselves  here  with  the  translation  and  will  only  look  at 
the  symbolic  representation. 

The  first  line  specifies  loading  the  contents  of  ADRl  into  the  accu- 
mulator A.  Referring  to  Figure  3.1,  the  contents  of  ADRl  are  the  first 
operand.  "OPl This  first  instruction  therefore  results  in  transferring 
OPl  from  the  memory  into  the  accumulator.  This  is  shown  in  Figure 
3.2.  "ADRl"  is  a  symbolic  representation  for  the  actual  16-bit  address 
in  the  memory.  Somewhere  else  in  the  program,  the  ADRl  symbol  will 
be  defined.  It  could,  for  example,  be  defined  as  being  equal  to  the  ad- 
dress "100". 

This  load  instruction  will  result  in  a  read  operation  from  address  100 
(see  Figure  3.2),  the  contents  of  which  will  be  transferred  along  the  data 


ADRl 


OP  5 


ADH2 


OP2 


ADR3 


RES 


ADDRESSES 


96 


BASIC  PROGRAMMING  TECHNIQUES 


Fig.  3.2:  LD  A,  (ADRl):  OPl  is  I  oaded  from  Memory 

bus  and  deposited  inside  the  accumulator.  You  will  recall  from  the  pre- 
vious chapter  that  arithmetic  and  logical  operations  operate  on  the 
accumulator  as  one  of  the  source  operands.  (Refer  to  the  previous 
chapter  for  more  details.)  Since  we  wish  to  add  the  two  values  OPI  and 
OP2  together,  we  must  first  load  OPl  into  the  accumulator.  Then,  we 
will  be  able  to  add  the  contents  of  the  accumulator,  i.e.,  add  OPl  to 
OP2.  The  right-most  field  of  this  mstruction  is  called  a  conimeni  field. 
It  is  ignored  by  the  assembler  program  at  translation  lime,  but  is  pro- 
vided for  program  readability.  In  order  to  understand  what  the  pro- 
gram does.  It  is  of  paramount  importance  to  use  good  comment.s.  This 
IS  called  documenling  a  program. 

Here  the  comment  is  self-explanatory:  the  value  of  OPl,  which  is 
located  at  address  ADRl,  is  loaded  into  the  accumulator  A. 

The  result  of  this  first  instruction  is  illustrated  by  Figure  3.2,  The 
second  instruction  of  our  program  is: 

LD  HL,  (ADR2) 

It  specifies:  "Load  from  (ADR2)  into  registers  H  and  L."  In  order 
to  read  the  second  operand,  OP2,  from  the  memory,  we  must  first  place 
its  address  into  a  register  pair  of  the  Z80,  such  as  H  and  L.  Then,  we 
can  add  the  contents  of  the  memory  location  whose  address  is  in  H  and 
L  to  the  accumulator. 

ADDA,  (HL) 

Referring  to  Figure  3.1,  the  contents  of  memory  location  ADR2  are 
0P2,  our  second  operand.  The  contents  of  the  accumulator  are  now 
OPl,  our  first  operand.  As  a  result  of  the  execution  of  this  instruction, 
OP2  will  be  fetched  from  the  memory  and  added  to  OPI.  This  is  il- 
lustrated in  Figure  3.3 
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Fig.  3.3:  ADD  A,  (HL) 


The  sum  will  be  deposited  in  the  accumulator.  The  reader  will 
remember  that,  m  the  case  of  the  Z80,  the  results  of  the  arithmetic  oper- 
ation are  deposited  back  into  the  accumulator.  In  other  processors,  it 
may  be  possible  to  deposit  these  results  in  other  registers,  or  back  into 
the  memory, 

The  sum  of  OPl  and  OP2  is  now  contained  in  the  accumulator.  To 
complete  our  program,  we  simply  have  to  transfer  the  contents  of  the 
accumulator  into  memory  location  ADR3,  in  order  to  store  the  results 
at  the  specified  location.  This  is  performed  by  the  fourth  instruction  of 
our  program: 

LD  (ADR3),  A 

This  instruction  loads  the  contents  of  A  into  the  specified  address 
ADR3.  The  effect  of  this  final  instruction  is  illustrated  by  Figure  3.4. 


Fig.  3.4:  LD  (ADR3),  A  (Save  Accumulator  in  Memory) 
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Before  execution  of  the  ADD  operation,  the  accumulator  contained 
OPi  {see  Figure  3.3).  After  the  addition,  a  new  result  has  been  written 
into  the  accumulator.  It  is  "OPI  +  OP2",  Recall  that  the  contents  of 
any  register  within  the  microprocessor,  as  well  as  any  memory  location, 
remain  the  same  after  a  read  operation  has  been  performed  on  this 

register.  In  other  words,  reading  the  contents  of  a  register  or  memory 
location  does  not  change  its  contents.  It  is  only,  and  exclusively,  a  write 
operation  into  this  register  location  that  will  change  its  contents.  In  this 
example,  the  contents  of  memory  locations  ADRI  and  ADR2  remain 
unchanged  throughout  the  program.  However,  after  the  ADD  instruc- 
tion, the  contents  of  the  accumulator  will  have  been  modified,  because 
the  output  of  the  ALU  has  been  written  into  the  accumulator.  The 
previous  contents  of  A  are  then  lost. 

Actual  numerical  addresses  may  be  used  mstead  of  ADRI,  ADR2, 
and  ADR3.  In  order  to  keep  symbolic  addresses,  it  will  be  necessary  to 
use  so-called  "pseudo-instructions"  which  specify  the  value  of  these 
symbolic  addresses,  so  that  the  assembly  program  may,  during  transla- 
tion, substitute  the  actual  physical  addresses.  Such  pseudo-instructions 
could  be,  for  example: 

APR]  =  lOOH 
ADR2  =  I20H 
ADR3  =  200H 

Exercise  3.1:  Now  dose  this  book.  Refer  only  to  (he  list  of  instructions 
at  the  end  of  the  book.  Write  a  program  which  will  add  two  numbers 
stored  at  memory  locations  LOCI  and  LOC2.  Deposit  the  results  at 
memory  location  LOC3.  Then,  compare  your  program  to  the  one 
above. 

16-Bi(  Addition 

An  8-btt  addition  will  only  allow  the  addition  of  8-bit  numbers,  i.e., 
numbers  between  0  and  255,  if  absolute  binary  Is  used.  For  most  prac- 
tical applications  it  is  necessary  to  add  numbers  having  16  bits  or  more, 
i.e.,  to  use  multiple  precision.  We  will  here  present  examples  of  arith- 
metic on  i  6-bit  numbers.  They  can  be  readily  extended  to  24,  32  bits  or 
more  (always  multiples  of  8  bits).  We  will  assume  that  the  first  operand 
is  stored  at  memory  locations  ADR!  and  ADRI-1.  Since  OPI  is  a  16-bit 
number  this  time,  it  will  require  two  8-bit  memory  locations.  Similarly, 
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OP2  wilt  be  siorcd  at  ADR2  and  ADR2-1 .  The  result  is  lo  be  depoMicd 
ai  memory  addresses  ADR3  and  ADR.l-t.  Tins  is  illu.slruied  m  l  igure 
3.5.  H  mdicaics  the  high  haircbsis  8  through  15),  while  1,  indicaics  ihe 
low  half  {bus  0  through  7). 


ADB3-! 


MM3-  I 


lOPIlH 


[OPI  IS 


iOP3!H 


Fig.  3.5:  16-Bif  Addition— The  Operands 


The  logic  of  the  program  is  exactly  tike  the  previous  one.  First,  the 
lower  half  of  the  two  operands  will  be  added,  since  the  microprocessor 
can  only  add  on  8  bus  at  a  time.  Any  carry  generated  by  the  addition  of 
these  low  order  bytes  will  automatically  be  stored  in  the  internal  carry 
bit  ("C").  Then,  the  high  order  half  of  the  two  operands  wilt  be  added 
together  along  with  any  carry,  and  the  result  will  be  saved  in  the 
memory.  The  program  appears  below: 


LD    A,  (ADRl) 
LD    HL,  ADR2 
ADD  A,  (HL), 
LD    (ADR3),  A 
LD    A,  (ADRl-I) 
DEC  HL 
ADC  A,  (HL) 
LD    {ADR3-I),  A 


LOAD  LOW  HALF  OF  OPI 
ADDRESS  OF  LOW  HALF  OF  OP2 
ADD  OPI  AND  OP2  LOW 
STORE  RESULT,  LOW 
LOAD  HIGH  HALF  OF  OPI 
ADDRESS  OF  HIGH  HALF  OF  OP2 
{OPI  +  0P2)  HIGH  +  CARRY 
STORE  RESULT,  HIGH 
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The  first  four  instructions  of  this  program  are  identical  to  the  ones 
used  for  the  8-bit  addition  m  the  previous  section.  They  result  in  adding 
the  least  significant  halves  (bits  0-7)  of  OPl  and  OP2.  The  sum,  called 
"RES"  is  stored  at  memory  location  ADR3  (see  Figure  3.5), 

Automatically,  whenever  an  addition  is  performed,  any  resulting 
carry  (whether  "0"  or  "I")  ts  saved  in  the  carry  bit  C  of  the  flags 
register  (register  F).  If  the  two  numbers  do  generate  a  carry,  then  the  C 
bit  will  be  equal  to  "I"  (it  will  be  set),  if  the  two  8-bit  numbers  do  not 
generate  any  carry,  the  value  of  the  carry  bit  will  be  "0". 

The  next  four  instructions  of  the  program  are  essentially  like  those 
used  in  the  previous  8-bit  addition  program.  This  time  they  add 
together  the  most  significant  half  (or  high  half,  i.e.,  bits  8-15)  of  OPl 
and  OP2,  plus  any  carry,  and  store  the  result  ai  address  ADR3-i. 

After  execution  of  this  8~instruction  program,  the  16-bil  result  is 
stored  at  memory  locations  ADR3  and  ADR3-1,  as  specified.  Note, 
however,  that  there  is  one  difference  between  the  second  half  of  this 
program  and  the  first  half.  The  "ADD"  instruction  which  has  been 
used  is  not  the  same  as  in  the  first  half,  in  the  first  half  of  this  program 
(the  3rd  mstruction),  we  had  used  the  "ADD"  instruction.  This  instruc- 
tion adds  the  two  operands,  regardless  of  the  carry.  In  the  second  half, 
we  use  the  "ADC"  instruction,  which  adds  the  two  operands  together, 
plus  any  carry  that  may  have  been  generated.  This  is  necessary  m  order 
to  obtain  the  correct  result.  The  addition  initially  performed  on  the  low 
operands  may  result  in  a  carry.  Such  a  possible  carry  must  be  taken  into 
account  in  the  second  half  of  the  addition. 

The  question  which  comes  naturally  then  is;  what  if  the  addition  of 
the  high  half  of  the  operands  also  results  in  a  carry?  There  are  two  pos- 
sibilities: [he  first  one  is  to  assume  that  this  ts  an  error.  This  program  ts 
then  designed  to  work  for  results  of  only  up  to  16  bits,  but  not  17:  The 
other  one  is  to  include  additional  instructions  to  test  explicitly  for  the 
possibility  of  a  carry  at  the  end  of  this  program.  This  is  a  choice  which 
the  programmer  must  make,  the  first  of  many  choices. 

Note:  we  have  assumed  here  that  the  high  part  of  the  operand  is 
stored  "on  top  of"  the  lower  part,  i.e.,  at  the  lower  memory  address. 
This  need  not  necessarily  be  the  case,  in  fact,  addresses  are  stored  by 
the  ZSO  in  the  reverse  manner:  the  low  part  is  first  saved  in  the  memory, 
and  the  high  part  is  saved  in  the  next  memory  location,  in  order  to  use  a 
common  convention  for  both  addresses  and  data,  it  is  recommended 
that  data  also  be  kept  with  the  low  part  on  top  of  the  high  part.  This  is 
illustrated  in  Figure  3.6. 
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(OPUL 
(OPIiH 


10P2)L 
(0P2JH 


il!E5)H 


Fig.  3.6:  Storing  Operands  in  Reverse  Order 

When  operating  on  multibyte  operand,  it  is  important  to  keep  jn  mind 
two  essentia!  conventions: 
—the  order  in  which  data  is  stored  in  the  memory. 
— where  data  pomters  are  pointing:  iow  byte  or  high  byte. 
Exercises  3.2  and  3.3  are  designed  to  clarify  this  point. 


Aoei  f ) 

ADS!*  I 


Exercise  3.2:  Rewnle  the  I6-bil  adciiaon  program  above  wilh  the 
memory  layout  indicated  in  Figure  3.6. 

Exercise  3.3:  Assume  now  t/iat  ADRi  does  not  pomi  to  the  lower  lialf 
ofOPl  (as  in  Figures  3.5  or  3.6),  but  points  to  the  higher  part  ofOPl. 
This  is  illustrated  in  Figure  3. 7.  Again,  write  the  corresponding  pro- 
gram. 
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(OK)H 


Fig.  3.7:  Poinling  to  the  High  Byte 


It  is  Ihe  programmer,  i.e.,  you,  who  must  decide  how  lo  store  16-bit 
numbers  (i.e.,  low  part  or  high  pan  first)  and  also  whcthw  yooTaddFesfS 
relerences  point  to  the  lower  or  to  the  higher  half  of  suA  numbers.  This 
fs  airather  cTtoice  which  you  will  letm  m  mate  when  designing 
algorithms  or  data  structures. 

The  programs  presented  above  are  traditional  programs,  using  the 
accumulator.  We  will  now  present  an  alternative  program  for  the  16-bil 
addition  that  does  not  use  the  accumulator,  but  instead  uses  some  of 
the  special  16~bii  instructions  available  on  the  Z80.  Operands  will  be 
a^umed  to  be  stored  as  indicated  in  Figure  3.S.  The  program  is: 


W  HL.{ADRI) 
LD  BC,  (ADR2I 
ADDHL,  BC 

(ADR3).  HL 


LOAD  HL  WITH  OPl 
LOAD  BC  WITH  OP2 
ADD  16  BITS 
STORE  RES  INTO  ADR3 

Noite  how  mudi  shorter  this  program  is,  compared  to  our  previous  ver- 
sion. It  is  more  "elegant."  a  liniiied manner,  the Z80 alfom registers 
H  and  L  lo  be  used  as  a  i6-bi{  accumulator. 
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Exercise  J. 4:  Using  the  16-hil  instructions  which  have  just  been  intro- 
duced, write  an  addition  program  for  S2'bil  operands,  assuming  thai 
^mm^  are  stored  as  sftowar  M  F^mm  3.8.  (The  answer  ofip&m 

LD  HL.  (ADRI) 
LD  BC,  (ADR2) 
ADD  HL,  BC 
ID  (ADR3) 
LD  HL,  (ADRl  +  2) 
LD  BC,  (ADR2  +  2) 
ADC  HL,  BC 
LD  (ADR3+2> 


Mm 


HIGH 

OPS  I 


0?R2 

low 


mt 


Fig.  3.8:  A  32-Btt  Aiktitioii 
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Now  that  we  have  learned  to  perfOTUi  a  binary  addition,  let  us  turn  to 
subtraction. 

Infilracting  16-Bit  Numbers 

Doing  an  8-bil  subtract  would  be  too  simple.  Lei  us  keep  it  as  an  ex- 
ercise and  directly  perform  a  16-bil  subtract.  As  usual,  our  two  num- 
bers, OPI  and  OP2,  are  stored  at  addresses  ADRl  and  ADR2.  The 
memory  layom  will  be  assumed  to  be  that  ol  Figure  3.6.  in  order  lo 
subtract,  we  will  use  a  sttbti^  op^tian  (SBC)  insloUi  of  an 
operatipD  (AOPK 

BMer^  3,S:  Now  write aWi^N)^6n  jaognm. 

The  pro-am  ai^ieais  below,  tlie  data  paths  are  shown  in  Figwe  3.^. 

LD  HL.(ADRl)  OPI  INTO  HL 
LD  DE,  (AX>R2)  OP2  INTO  DE 
AND  A  CLEAR  CARRY 

SBC  HL.  DE  OPI  —  OP2 

LD    (ADR3),  HL         RES  INTO  ADR3 

The  program  is  essentially  like  the  one  developed  for  16-bit  addition. 
However,  the  Z80  instruction-set  has  two  types  of  additions  on  double 
jhegisters:  ADD  and  ADC,  but  only  one  type  of  subtraction:  SBC. 

4\s  a  te$vitt  two  chiniiss;s  ean  W  noted. 
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MEMORY 


H  1. 

10P1  ^1 

(OP<iH 

(OPliL 

(OPIiH 

Fig.  3.9:  !6-Bit  Load  —  LD  HL,  (ADRI) 

A  first  change  is  the  use  of  SBC  instead  of  ADD. 

The  other  change  is  the  "AND  A"  instruction,  used  to  dear  the  carry 
flag  prior  io  [he  subtraction.  This  instruction  does  not  modify  the  value 
Of  A. 

This  precaution  is  necessary  because  the  Z80  is  equipped  with  two 
modes  of  addition,  with  and  without  carry  on  the  H  and  L  register,  but 
with  only  one  mode  of  subtraction,  the  SBC  instruction  of  "subtract 
with  carry"  when  operating  on  the  HL  register  pair.  Because  SBC  auto- 
maiicaiiy  takes  into  account  the  value  of  the  carry  bit,  it  must  beset  to  0 
prior  10  starting  the  subtraction.  This  is  ihc  role  of  the  "AND  A"  in- 
struction. 

Exercise  3.6:  Rewnie  lite  siihlraciion  program  wiihoitl  iisui}>  ilte 
specialized  16-bii  inssrucdott. 

Exercise  3. 7:  H  'nte  ihe  subtract  program  fur  8-hit  opera fu/s. 

It  must  be  remembered  that  in  the  case  of  two's  compiement  anihnie- 
nc,  the  final  value  of  the  carry  flag  has  no  meaning.  If  an  overflow  con- 
dition has  occurred  as  a  result  of  the  subtraction,  then  the  o\'ernow  bit 
(bit  V)  of  the  (lags  register  will  have  been  set.  it  can  then  be  tested. 
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The  examples  just  presented  are  simple  binary  additions  or  subtrac- 
tions. However,  another  type  of  arithmetic  may  be  necessary;  it  is  BCD 
arithmetic. 

BCD  ARITHMETIC 

8-Bit  BCD  Addition 

The  concept  of  BCD  arithmetic  has  been  presented  in  Chapter  1.  Let 
us  recall  its  features,  it  is  essentially  used  for  business  applications 
where  U  is  imperative  to  retam  every  significant  digit  in  a  result,  in  the 
BCD  notation,  a  4-bU  nibble  is  used  to  store  one  decimal  digit  (0 
through  9).  As  a  result,  every  8-bit  byte  may  store  two  BCD  digits. 
(This  !s  called  packed  BCD).  Let  us  now  add  two  bytes  each  containmg 
two  BCD  digits. 

In  order  to  identify  the  problems,  let  us  try  some  numeric  examples 
first. 

Let  us  add  "01"  and  "02": 

"01 "  is  represented  by:  0000  0001 
"02"  is  represented  by:  0000  0010 

The  result  is;  0000  0011 

This  is  the  BCD  representation  for  "03'V  (If  you  feel  unsure  of  the 
BCD  equivalent,  refer  to  the  conversion  table  at  the  end  of  the  book.) 
Everything  worked  very  simply  in  this  case.  Let  us  now  try  another  ex- 
ample. 

"08"  is  represented  by  0000  1000 
"03"  is  represented  by  0000  OOII 

Exercise  3.8:  Compute  the  sum  of  the  two  numbers  above  m  the  BCD 
representation.  What  do  you  obtain?  (answer  follows) 

If  you  obtain  "0000  1011",  you  have  computed  the  binary  sum  of  8 
and  3.  You  have  indeed  obtained  II  in  binary,  Unfortunately,  "101 1" 
is  an  illegal  code  in  BCD.  You  should  obtain  the  BCD  representation  of 
"I!",  I.e.,  0001  0001! 

The  problem  stems  from  the  fact  that  the  BCD  representation  uses 
only  the  first  ten  combinations  of  4  digits  in  order  to  encode  the  decimal 
symbols  0  through  9.  The  remaining  six  possible  combinations  of  4 
digits  are  unused,  and  the  illegal  "lOIl"  is  one  such  combination.  In 
other  words,  whenever  the  sum  of  two  BCD  digits  is  greater  than  9, 
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then  one  must  add  6  to  the  result  in  order  to  skip  over  the  6  unused 
codes. 

Add  [he  binary  representation  of  "6"  to  101 1: 


This  is,  indeed,  "11"  in  the  BCD  notation!  We  now  have  the  correct 
result. 

This  example  illustrates  one  of  the  basic  difficulties  of  the  BCD 
mode.  One  must  compensate  for  the  six  missing  codes.  A  special  in- 
struction, "DAA",  called  "decimal  adjust,"  must  be  used  to  adjust  the 
result  of  the  binary  addition.  (Add  6  if  the  result  is  greater  than  9.) 

The  next  problem  is  illustrated  by  the  same  example.  In  our  example, 
the  carry  will  be  generated  from  the  lower  BCD  digit  (the  nght-mosi 
one!  into  the  left-most  one.  This  internal  carry  must  be  taken  into  ac- 
couns  and  added  to  the  second  BCD  digit.  The  addition  instruction 
takes  care  of  this  automatically.  However,  it  is  often  convenient  to 
detect  this  interna!  carry  from  bit  3  to  bit  4  (the  "half-carry").  The  H 
Hag  is  provided  for  this  purpose. 

As  an  example,  here  is  a  program  to  add  the  BCD  numbers  "11"  and 
"22": 


In  this  program,  we  are  using  a  new  symbol  "H",  The  "H"  sign 
within  the  operand  field  of  the  instruction  specifies  that  the  data  it 
follows  IS  expressed  in  hexadecimal  notation.  The  hexadecimal  and  the 
BCD  representations  for  digits  "0"  through  "9"  are  identical.  Here  we 
wish  to  add  the  literals  (or  constants)  "11"  and  "22",  The  result  is 
stored  at  the  address  ADR.  When  the  operand  is  specified  as  part  of  the 
instruction,  as  it  is  in  the  above  example,  this  is  called  immediate  ad- 
dressmg.  (The  various  addressing  modes  will  be  discussed  in  detail  in 
Chapter  5.)  Storing  the  result  at  a  specified  address,  such  as  LD  (ADR),  A 
is  called  absolute  addressing  when  ADR  represents  a  16-bit  address. 


1011  (illegal  binary  resuh} 
+  0110     (  +  6) 


The  result  is: 


0001  0001 


LD  A,  IIH 
ADD  A,  22H 
DAA 

LD    (ADR),  A 


LOAD  LITERAL  BCD  'U' 
ADD  LITERAL  BCD  *22' 
DECIMAL  ADJUST  RESULT 
STORE  RESULT 
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! 

1  1 

1 

} 

1 

\  ADB 

(RESliir) 

Fig.  3.10:  Storing  BCD  Digits 

This  program  is  analogous  to  the  8-bit  binary  addition,  but  uses  a 
new  instruction:  "DAA",  Let  us  illustrate  its  role  in.  an  example.  We 
will  first  add  "11"  and  "22"  in  BCD: 

0001000 f  (in 
+  00100010  (22) 

=  OOIIOOll  (33) 

3  3 

The  result  is  correct,  usmg  the  rules  of  binary  addition. 

Lei  us  now  add  "22"  and  "39",  by  using  the  rules  of  binary  addi- 

00100010  (22) 
+  00111001  (39) 

='0I0110II 

5  ? 

"101 1"  IS  an  illegu/  BCD  code.  This  is  because  BCD  uses  only  the 
first  10  binary  codes,  and  "skips  over"  the  next  6.  We  must  do  the 
same,  i.e.  add  6  to  the  result: 

01011011    (binary  result) 
4-        0110  (6) 


=  01100001 
6  i 


(6i) 


This  IS  the  correct  BCD  result. 
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Exercise  3.9:  Could  we  move  I  he  DA  A  instruct  ton  in  the  program  after 
the  instruction  LD  (ADR},  A? 


BCD  Subtraction 

BCD  subtraction  is,  m  appearance,  complex,  in  order  lo  perform  a 
BCD  subtraction,  one  must  add  the  ten's  complement  of  the  number, 
just  as  one  adds  the  two's  complement  of  a  number  lo  perform  a  binary 
subtracL  The  ten's  complement  is  obtained  by  computing  the  comple- 
meni  to  9,  then  adding  "I  ".  This  requires  typically  three  to  four  opera- 
tions on  a  ssandard  microprocessor.  However,  the  Z80  is  equipped  with 
a  powerful  DAA  mstruction  which  simplifies  the  program. 

The  DAA  instruction  automatically  adjusts  the  value  of  the  result  m 
the  accumulator,  depending  on  the  value  of  the  C,  H  and  N  flags  before 
DAA,  \o  the  correct  value,  (See  the  next  chapter  for  more  details  on 
DAA.i 


16-Bit  BCD  Addition 

16-bit  addition  is  performed  just  as  simply  as  in  the  binary  case.  The 
program  for  such  an  additson  appears  below: 


LD    (ADR3  +  i),  A     STORE  (RESULT)  HIGH 

Packed  BCD  Subtract 

Elementary  BCD  addition  and  subtraction  have  been  described. 
However,  in  actual  practice,  BCD  numbers  mclude  any  number  of 
bytes.  As  a  simplified  example  of  a  packed  BCD  subtract,  we  will 
assume  that  the  two  numbers  Nl  and  N2  include  the  same  number  of 
BCD  bytes.  The  number  of  bytes  is  called  COUNT:  The  register  and 


LD    A,  (ADR!) 
LD  HL,fADR2) 
ADD  A,  (HL) 
DAA 

LD    (ADR3),  A 
LD    A,  (ADRl  +  1) 
INC  HL 
ADC  A,(HL) 
DAA 


LOAD  (OPI)  L  INTO  A 
LOAD  ADR2  INTO  HL 
(OPI  +  0P2)  LOW 
DECIMAL  ADJUST 
STORE  (RESULT)  LOW 
LD  (OPI)  H  INTO  A 
POINT  TO  ADR2  -f  i 
(OPI  +  0P2}  HIGH  +  CARRY 
DECIMAL  ADJUST 
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memory  allocation  is  shown  m  Figure  3.1 1.  The  program  appears 
below: 


BCDPAK 


MINUS 


LD 

B,  COUNT 

LD 

DE,  N2 

LD 

HL,  Nl 

AND 

A 

LD 

A,  (DE) 

SBC 

A.(HL) 

DAA 

LD 

(HL),  A 

INC 

DE 

INC 

HL 

DJNZ 

MINUS 

CLEAR  CARRY 
N2  BYTE 
N2  -  NI 

STORE  RESULT 


DEC  B,  LOOP  UNTIL  B  =  0. 


COUNT 


Fig.  3.11:  Packed  BCD  Subtract:  Nl-*—  N  2  -  Nl 

Nl  and  N2  represent  the  addresses  where  the  BCD  numbers  are  stored. 
These  addresses  will  be  loaded  m  register  pairs  DE  and  HL; 

BCDPAK  LD       B,  COUNT 
LD       DE,  N2 
LD       HL,  Nl 
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Then,  in  aniicipatson  of  the  first  subtraction,  the  carry  bit  must  be 
cleared.  U  has  been  pointed  out  that  the  carry  bit  can  be  cleared  in  a 
number  of  equivalent  ways.  Here,  for  example,  we  use; 

AND  A 

The  first  byte  of  N2  is  loaded  into  the  accumulator,  then  the  first  byte 
of  N!  is  subtracted  from  it.  The  DA  A  instruction  is  then  used,  to  obtain 
the  correct  BCD  value: 

MINUS  LD  A,  (DE) 
SBC  A,  (HL) 
DAA 

The  result  is  then  stored  mto  Nl: 

LD       (HL),  A 

Finally,  the  pointers  !o  the  current  byte  are  incremented; 

INC  DE 
INC  HL 

The  counter  is  decremented  and  the  subtraction  loop  is  executed  until  it 
reaches  the  value  "0"; 

DJNZ  MINUS 

The  DJNZ  instruction  is  a  special  Z80  instruction  which  decrements 
register  B  and  jumps  if  it  is  not  zero,  m  a  single  instruction, 

ilxercise  3. 10:  Compare  the  pm^iram  above  to  the  one  for  the  l6-bii 
binary  addition.  What  is  the  difference? 

Exercise  3.11:  Can  you  exchange  the  roles  of  DE  and  HL?  (Hint:  Be 
careful  with  SBC.) 

E.xercise  3.12:  Write  the  subtraction  program  for  a  16-bii  BCD. 
BCD  Flags. 

In  BCD  mode,  the  carry  flag  set  as  the  result  of  an  addition  indicates 
the  fact  that  the  result  is  larger  than  99.  This  is  not  like  the  two's  com- 
plement situation,  since  BCD  digits  are  represented  in  true  binary.  Con- 
versely, the  presence  of  the  carry  flag  after  a  subtraction  indicates  a 
borrow. 

Instruction  Types 

We  have  now  used  two  types  of  microprocessor  instructions.  We 
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have  used  LD,  which  loads  the  accumulator  from  the  memory  address, 
or  stores  us  contents  at  the  specified  address.  This  is  a  data  transfer  m- 

siruction. 

Ne,\t,  \vc  have  used  aruhniettc  instructions,  such  as  ADD,  SUB, 
ADC  and  SBC.  They  perform  addition  and  subtraction  operations. 
More  ALU  instructions  will  be  introduced  soon  in  this  chapter. 

Still  other  types  oi  inslruction,s  are  available  within  the  micropro- 
cessor which  we  have  not  used  yet.  They  are  in  particular  "jump"  in- 
structions, which  will  modify  the  order  m  which  the  program  ls  being 
executed.  This  new  type  of  instruction  will  be  introduced  in  our  next  ex- 
ample. Note  thai  jump  instructions  are  often  called  "branch"  for  con- 
ditional situations,  i.e.  instances  where  there  is  a  logical  choice  in  the 
program.  The  "branch"  derives  its  name  from  the  analogy  to  a  tree, 
and  implies  a  fork  m  the  repre.sentation  of  the  program. 

MULTIPLICATION 

Lei  us  now  examine  a  more  complex  arithmetic  problem:  the  multi- 
plication of  binary  numbers,  in  order  to  introduce  the  algorithm  for  a 
binary  multiplication,  let  us  start  by  examining  a  usual  decimal  multi- 
plication: We  will  multiply  12  by  23. 

12  (MultipHcand) 
X    23  (Multiplier) 

36   (Partial  Product) 
+  24 

=  276   (Final  Result) 


The  multipiication  is  performed  by  multiplying  the  right-most  digit  of 
the  multiplier  by  the  multiplicand,  i.e.,  "3"  x  "  12"=  The  partial  prod- 
uct is  "36".  Then  one  multiplies  the  next  digit  of  the  multiplier,  i.e., 
"2",  by  "12",  "24"  is  then  added  to  the  partial  product. 

But  there  is  one  more  operation:  24  is  offset  to  the  left  by  one  posi- 
tion. We  will  say  that  24  is  shifted  left  by  one  position.  Equivalently,  we 
could  have  said  that  the  partial  product  (36)  had  been  shifted  one  posi- 
tion to  the  right  before  adding. 

The  (wo  numbers,  correctly  shifted,  are  then  added  and  the  sum  is 
276.  This  is  simple.  The  binary  multiplication  is  performed  in  exactly 
the  same  way. 
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Let  us  look  at  an  example.  We  will  multiply  5  X  3; 

(5)  lOI  (MPD) 

(3)     X    Oil  (MPR) 

101  {PP) 
101 
000 

(15)       01111  (RES) 

In  order  to  perform  the  multiplication,  we  operate  exactly  as  we  did 
above.  The  formal  representation  of  this  algorithm  appears  in  Figure 
3-12.  It  is-a  flowchart  for  the  algorithm,  our  first  flowchart.  Let  us  ex- 
amine It  more  closely. 


RESUIT  = 
RESULT  +MPD 


LEFT  SHIFT  (1)  MPD 
OR  SIGHT  SHIFT  il}  RES 


i 


NEXT  ISB  (MPRl 


DOME 

Fig.  3,12:  The  Basic  Miiitipiication  Algorithm— Flowchart 


This  flowchart  is  a  symbolic  representation  of  the  algorithm  we  have 
just  presented.  Every  rectangle  represents  an  order  to  be  carried  out.  It 
will  be  translated  mto  one  or  more  program  instructions.  Every 
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diamond-shaped  symbol  represents  a  test  being  performed.  This  will  be 
a  branching  point  in  the  program,  if  the  test  succeeds,  we  will  branch  to 
a  specified  location.  If  the  test  does  not  succeed,  we  will  branch  to 
another  iocation.  The  concept  of  branching  will  be  explained  later,  in 
the  program  itself.  The  reader  should  now  examine  this  flowchart  and 
ascertain  that  it  does  indeed  exactly  represent  the  algorithm  which  has 
been  presented.  Note  that  there  is  an  arrow  coming  out  of  the  last  dia- 
mond at  the  bottom  of  the  fJowchart,  back  to  the  first  diamond  on  top. 
This  is  because  the  same  portion  of  the  flowchart  will  be  executed  eight 
times,  once  for  every  bit  of  the  multiplier.  Such  a  situation,  where  ex- 
ecution will  restart  at  the  same  point,  is  called  a  program  loop  for  ob- 
vious reasons. 

Exercise  3.13:  Multiply  "4"  by  "7"  in  binary,  using  iheflowcharl,  and 
verify  that  you  obtain  "28".  If  you  do  not,  try  again.  It  is  only  if  you 
obtain  the  correct  result  that  you  are  ready  to  translate  this  flowchart 
Into  a  program. 

8-By-8  Multiplication 

Let  us  now  translate  this  flowchart  mto  a  program  for  the  Z80.  The 
complete  program  appears  m  Figure  3.13.  We  are  gomg  to  study  it  in 
detail.  As  you  will  recall  from  Chapter  1 ,  programming  consists  here  of 
translating  the  flowchart  of  Figure  3.12  into  the  program  of  Figure 
3.13,  Each  of  the  boxes  in  the  flowchart  will  be  translated  by  one  or 
more  m.slructions. 

it  is  assumed  that  MPR  and  MPD  already  have  a  value. 


MPY88    LD  BC,  (MFRAD) 

LD  B,  8 

LD  DE,  (MPDAD) 

LD  D,0 

LD  HL,0 

MULT    SRL  C 


JR 
ADD 
NOADD  SLA 
RL 
DEC 
JP 
LD 


NC,  NOADD 

HL,  DE 

E 

D 

B 

NZ.  MULT 
(RESAD),  HL 


LOAD  MULTIPLIER  INTO  C 

B  IS  BIT  COUNTER 

LOAD  MULTIPLICAND  INTO  E 

CLEAR  D 

SET  RESULT  TO  0 

SHIFT  MULTIPLIER  BIT  INTO 

CARRY 

TEST  CARRY 

ADD  MPD  TO  RESULT 

SHIFT  MPD  LEFT 

SAVE  BIT  IN  D 

DECREMENT  SHIFT  COUNTER 
DO  IT  AGAIN  IF  COUNTER  0 
STORE  RESULT 


Fig.  3.13:  8x8  Multiptication  Program 
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Tim       Mc  ()if  tte  fJe^teeliitf t  is  an  init'mtmBiim  box.  It  is  necess«r5F 

to  sei  a  number  of  registers  or  memory  locations  to  "0".  as  this  pro- 
gram will  require  iheir  use.  The  registers  which  will  be  used  by  the 
m\Mp^<^mt  fm^^iBm2^pBm  In  l%ure  3.14. 


Fig  3. 14:  8x8  Multiplication — The  Registers 

Three  KE^E^r  pairs  of  the  Z80  are  used  for  the  multiplication  pro- 
gram. Tile  84>it  multiplier  is  assumed  to  reside  at  memory  address 
MPRAD.  TTte  multiplicand  1MP15  is  aissumed  to  i^ide  at  memoi^  ad- 
dress MPDAD.  Tlic  multiplier  and  the  multiplicand  respectively  will  be 
l0aded  into  registers  C  and  E  (see  Figure  3.14).  Register  B  will  be  used 

Registers  D  and  E  will  hold  ttte  mtiltiplicand  as  it  is  shifted  left  one 

bit  at  a  time. 

Note  that,  even  though  only  C  and  E  need  to  be  loaded  initially,  a  16- 
bit  load  must  be  used,  so  that  B  and  D  will  also  be  loaded  from  menMWy* 
and  will  Imve  toberes^  K^ectivdy  to  "8"  and  to  "0". 
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Finally,  ihe  results  of  an  8-bit  by  8-bil  multiplication  may  require  up 
to  16  bus.  This  is  because  2"  x  2"  =  2'^  Two  registers  must  therefore 
be  reserved  tor  the  result.  They  are  registers  H  and  L,  as  indicated  on 
Figure  3.14. 

The  first  step  is  to  load  registers  B,  C,  and  E  with  the  appropriate 
contents,  and  to  initialize  the  result  (the  partial  product)  to  the  value 
"0"  as  specified  by  the  flowchart  of  Figure  3.12.  This  is  accomplished 
by  the  following  instructions; 

MPY88    LD      BC,  (MPRAD) 
LD      B,  8 

LD     DE,  (MPDAD) 
LD      D,  0 
LD     HL,  0 

The  first  three  instructions  respectively  load  MPR  into  the  register  pair 
BC,  the  value  "8"  into  register  B,  and  MPD  into  the  register  pair  DE. 
Since  MPR  and  MPD  are  8-bit  words,  they  are,  in  fact,  loaded  into 
registers  C  and  E  respectively,  while  the  next  words  in  the  memory  after 
MPR  and  MPD  get  loaded  into  B  and  D.  This  is  shown  m  Figure  3.15 
and  3.16.  The  next  instruction  will  zero  the  contents  of  D. 

In  this  mukiplicaison  program,  the  multiplicand  will  be  shifted  left 
before  being  added  to  the  result  (remember  that,  optionally,  it  is  pos- 
sible to  shift  the  result  right  instead,  as  indicated  in  the  fourth  box  of 
the  flowchart  of  Figure  3.12).  The  multiplicand  MPD  will  be  shifted  in- 
to register  D  at  each  step.  This  register  D  must  therefore  be  initialized  to 
the  value  "0".  This  is  accomplished  by  the  fourth  instruction.  Finally, 
the  fifth  instruction  sets  the  contents  of  registers  H  and  L  to  0  m  a  smgle 
instruction, 

MEMORV 


Fig.  3.15:  LD  BC,  (MPRAD) 
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MEMORY 


Fig.  3.16:  LD  DE,  (MPDAD) 


Referring  back  to  the  flowchart  of  Figure  3.12,  the  next  step  is  to  test 
the  least  significant  btt(fhe  right-most  bit)o("  the  multiplier  MPR.  if  this 
bit  is  a  "1",  then  the  vaiue  of  MPD  must  be  added  to  the  partial  result, 
otherwise  it  will  not  be  added.  This  is  accomplished  by  the  next  three  in- 
structions: 

MULT  SRL  C 

JR      NC,  NOADD 
ADD  HL,  DE 

The  first  problem  we  must  solve  is  how  to  test  the  least  significant  bit  of 
the  multiplier,  contained  in  register  C.  We  could  here  use  the  BIT  in- 
struction of  the  280,  which  allows  testing  any  bit  in  any  register.  How- 
ever, in  this  case,  we  would  like  to  construct  a  program  as  simple  as 
possible,  using  a  loop.  If  we  were  using  the  BIT  instruction  here,  we 
would  first  test  bit  0,  then  later  test  bit  I,  and  so  on  until  we  reached  bit 
1 ,  This  would  require  a  different  instruction  every  lime,  and  a  simple 
loop  could  not  be  used.  In  order  to  shorten  the  length  of  the  program, 
we  must  use  a  different  instruction.  Here  we  are  ustng  a  shift  instruc- 
tion. 

Note;  There  is  a  way  to  use  the  BIT  instruction  and  a  loop,  but  this 
would  require  the  program  to  modify  itself,  a  practice  we  will  avoid. 
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SRL  is  a  new  type  of  operation  within  the  arithemetic  and  logical 
unit.  It  stands  for  "shift  right  logical."  A  logical  shift  to  the  right  is 
daracterized  by  the  fact  tnat  a"0"  comes  into  bit  position  7.  This  can 
be  contrasted  to  an  arithemtic  shift  to  the  right,  where  the  bit  coming 
into  position  7  is  identical  to  the  previous  value  of  bit  7.  The  different 
types  of  shift  operations  will  be  described  in  the  next  chapter.  The 
effect  of  the  SRL  C  instruction  is  illustrated  in  Figure  3.14  by  an  arrow 
coming  out  of  register  C  and  into  the  square  used  to  designate  the  carry 
bi t  ( also  called  "  C  "}.  At  this  point,  the  right-most  bit  of  the  MPR  «jQ 
be  in  the  carry  bit  C,  where  it  can  be  tested . 

The  next  instruction,  "JR  NC,  NOADD  is  a  Ju/n^  operation.  It 
means  "jump  on  no  carry"  (NC)  to  the  address  (the  label)  NOADD.  If 
the  contenc;  of  the  carry  bit  are  "0"  (no  carry),  then  ihe  program  will 
jump  to  the  address  NOADD.  If  the  conienis  ot  C  are  "  I  "  (the  carry 
bit  is  set),  then  no  branch  will  occur,  and  tHe  next  sequeni  ial  it^ni^ion 
will  be  executed,  i.e.,  the  instruction  "ADD  HL,  DE"  \m11  be  executed. 

This  instruction  specifies  thai  the  contents  of  D  and  E  be  added  to  H 
and  L,  with  the  result  in  H  and  L.  Since  E  contains  the  multiplicand 
MPD  (see  Figure  3.14),  this  adds  ihe  muhtplicand  to  the  partial  result. 

At  this  point,  regardless  of  whether  MPD  has  been  added  lo  the 
result  or  not,  the  multiplicand  must  beshifted  left  (this  is  the  fourth  box 
in  the  flowchart  of  Figiire  3.12).  This  is  accomplished  by: 

NOADD  SLA  E 

SLA  stands  for  "shift  left  ariihmelic."  It  has  jusi  been  explained  above 
that  there  are  two  types  of  shiti  operations,  a  logical  shift  and  an  arith- 
metic shii:.  This  is  the  arithmette#n®.  ta  ihe^st  of  a  Idft  sfti#,  a&il»A 
specifies  that  the  bit  coming  into  the  right  part  of  the  register  (the  least 
significant  bit)  be  a  "0"  Oust  as  in  the  case  of  an  SRL  before). 

As  an  example,  let  us  assume  that  the  ittilial  contents  of  regi^  E 
were  OOOOIOOI.  After  the  SLA  instruction,  the  contents  of  E  will  be 
0(X)1(X)10.  And  the  contents  of  the  carry  bit  will  be  0. 

However^  looit(fl|[  ^smk  at  Figure  3.14,  we  r^y  want  to  shift  the 
most  signifiQ^t  |«|t  fjealled  the  MSB)  of  E  directly  into  D  {(his  is  il- 
lusiraied  by  ttjtf  lults^  on  (he  illustration  coming  from  E  into  D). 
HOwe^,  there  is  no  iiHitMiGfibfit  w^ii  wilt  stfjft  a  dfmble  fluster  soch 
as  D  and  E  in  one  operation.  Once  the  contents  of  E  have  been  shifted, 
the  letl-mosl  bit  has  "fallen  into"  the  carry  bit.  We  must  collect  this  bit 
Mpom  ihe  eany  bte  and  shift  ii  into  register  D.  This  is  acGom|]jish«l  by 
itif  oext  itistruction: 

RL  D 
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RL  is  StiJI  another  type  of  shift  operation,  it  stands  for  "rotate  left." 
In  a  rolalion  operation,  as  opposed  to  a.  shift  operation,  this  bit  coming 
into  the  register  is  the  contents  of  the  carry  bit  C  (see  Figure  3.17).  This 
is  exactly  what  we  want.  The  contents  of  the  carry  bit  C  are  loaded  into 
the  right-most  part  of  D,  and  we  have  effectively  transferred  the  left- 
most bit  of  E. 

This  sequence  of  two  instructions  is  illustrated  in  Figure  3.18.  It  can 
be  seen  thai  the  bit  marked  by  an  X  in  the  most  significant  position  of  E 
will  first  be  transferred  into  the  carry  bit,  then  into  the  least  significant 
position  of  D.  Effectively,  it  will  have  been  shifted  from  E  into  D. 

At  this  point,  referring  back  to  the  flowchart  of  Figure  3. 12,  we  must 
point  to  the  next  bit  of  MPR  and  check  for  the  eighth  bit.  This  is  ac- 
complished by  decrementing  the  byte  counter,  contained  in  register  B 
(see  Figure  3.14).  The  register  is  decremented  by: 

DEC  B 

This  is  a  decrement  instruction,  which  has  the  obvious  effect. 

Finally,  we  must  check  whether  the  counter  has  decremented  to  the 
value  zero.  This  is  accomplished  by  checking  the  value  of  the  Z  bit.  The 
reader  wii!  recall  that  the  Z  (zero)  flag  indicates  whether  the  previous 
arithmetic  operation  (such  as  a  DEC  operation)  has  produced  a  zero 
result.  However,  note  that  DEC  HL,  DEC  BC,  DEC  DE,  DEC  IX, 
DEC  SP  do  not  affect  the  Z  flag.  If  the  counter  is  not  "0",  the  opera- 
tion is  not  finished,  and  we  must  execute  this  program  loop  agam.  This 
is  accomplished  by  the  next  instruction: 

JP  NZ  MULT  3^,^^  ^^^^ 


\  r 

^  r 

CARRY 


ROTATE  LEFf 


r\ r\  r\ 


CARRY 


RLC  instruction 
Fig.  3.17:  Shift  and  Rotate 
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C 


D 


X 


E 


Fig.  3.18:  Shifting  from  E  into  D 


This  is  a  jump  instruction  which  specifies  that  whenever  the  Z  bit  is 
not  set  (NZ  stands  For  non-zero  J,  a  jump  occurs  to  location  MULT.  This 
IS  the  program  loop,  which  will  be  executed  repeatedly  until  B  decre- 
ments to  the  value  0.  Whenever  B  decrements  to  the  value  0,  the  Z  bit 
will  be  set,  and  the  JP  NZ  instruction  will  fail.  This  will  result  in  the 
next  sequential  instruction  being  executed,  namely: 

LD  (RESAD),  HL 

This  instruction  merely  saves  the  contents  of  H  and  L,  i.e.,  the  result  of 
the  multiplication,  at  address  RESAD,  the  address  specified  for  the 
result.  Note  that  this  instruction  will  transfer  the  contents  of  both  regis- 
ters H  and  L  into  two  consecutive  memory  locations,  corresponding  to 
addresses  RESAD  and  RESAD  -i-  1 .  It  saves  16  bits  at  a  time. 

Exercise  3.14:  Could  you  write  the  same  multiplication  program  using 
the  BIT  instruction  (described  m  the  next  chapter)  instead  of  the  SRL  C 
instruction?  What  would  be  the  disadvantage? 

Let  us  now  improve  the  program,  if  possible: 

Exercise  3.  IS:  Can  JR  be  substituted  for  JP  at  the  end  of  the  program? 
If  so,  what  IS  the  advantage? 

Exercise  3.16:  Can  you  use  DJNZ  to  shorten  the  end  of  the  program? 
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Exercise  3.17;  Examine  the  two  instructions:  LD  D,  0  and  LD  HL.  Oat 
the  beginning  of  the  program.  Can  you  subslidile: 

XOR  A 
LD      D,  A 
LD      H,  A 
LD      L,  A 

If  so.  what  IS  the  impact  on  size  (number  of  bytes ^  and  speed? 

Note  that,  m  most  cases,  the  program  that  we  have  just  developed 
will  be  a  subroutine  and  the  final  instruction  in  the  subroutine  will  be 
RET  (return).  The  subroutine  mechanism  will  be  explained  later  m  this 
chapter. 

Important  SeJf-Tesj 

This  is  the  first  significant  program  we  have  encountered  so  far.  It  in- 
cludes many  different  types  of  instructions,  mciuding  transfer  instruc- 
tions (LD),  arithmetic  operations  (ADD),  logical  operations  (SRL, 
SLA,  RLj,  and  jump  operations  (JR,  JP).  It  also  implements  a  pro- 
gram loop,  m  which  the  lower  seven  instructions,  starting  at  address 
MULT,  are  executed  repeatedly.  In  order  to  understand  programming, 
it  is  essential  to  understand  the  operation  of  such  a  program  in  com- 
plete detail.  The  program  is  much  longer  than  the  previous  simple  arith- 
metic programs  we  have  developed  so  far,  and  it  should  be  studied  in 
detail.  An  important  exercise  will  now  be  proposed.  The  reader  is 
strongly  urged  to  do  this  exercise  completely  and  correctly  before  pro- 
ceeding. This  will  be  the  only  real  proof  that  the  concepts  presented  so 
far  have  been  understood.  If  a  correct  result  is  obtained,  it  will  mean 
that  you  have  really  understood  the  mechanism  by  which  instructions 
manipulate  information  in  the  microprocessor,  transfer  it  between  the 
memory  and  the  registers,  and  process  it.  If  you  do  not  obtain  the  cor- 
rect result,  or  if  you  do  not  do  this  exercse,  it  is  likely  that  you  will  ex- 
perience difficulties  later  in  writing  programs  yourself.  Learning  to  pro- 
gram requires  personal  practice.  Please  pause  now,  take  a  piece  of 
paper,  or  use  the  illustration  of  Figure  3.19,  and  do  the  following  exer- 
cise: 

Exercise  3.18:  Every  time  that  a  program  is  written.  It  should  be  verified 
by  hand,  in  order  to  ascertain  that  its  results  will  be  correct.  We  are  go- 
ing to  do  just  tiiat:  tfie  goal  of  this  exercise  is  to  fill  in  the  table  of  Figure 
3.  J 9  completely  and  accurately. 
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LABEL 

INSTRUCTION 

8 

C 

r 

D 

E 

H 

L 

Fig.  3.19:  Form  for  Multiplication  Exercise 


You  may  wanl  to  write  directly  on  Figure  3.19  or  make  a  copy  of  it. 
You  must  determine  the  contents  of  every  relevant  register  in  the  Z80 
after  the  execution  of  each  instruction  in  the  program,  from  beginning 
to  end.  All  the  registers  used  by  the  program  of  Figure  3.13  are  shown 
in  Figure  3,19.  From  left  to  right,  they  are  registers  B  and  C,  the  carry 
C,  registers  D  and  E,  and,  finally,  registers  H  and  L.  On  the  left  pan  of 
this  illustration,  fill  in  the  label,  if  applicable,  and  then  the  instructions 
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being  executed.  On  the  right  of  the  instruction,  fill  in  the  contents  Of 
each  register  after  execution  of  the  instruction.  Whenever  the  contents 
of  a  register  are  not  known  (indefinite),  you  may  use  dashes  to  repre- 
sent its  contents.  Let  us  start  filling  m  this  table  together.  You  will  then 
have  to  fill  it  out  by  yourself  until  the  end.  The  first  line  appears  below: 


LABEL 

INSTRUCTION 

B 

C 

C 

D    1  E 

H 

L 

MPY88 

LD  BC,(0200) 

00 

03 

Fig.  3.20:  Multiplication:  After  One  Instruction 


We  will  assume  here  that  we  are  multiplying  "3"  (MPR)  by  "5" 
(MPD). 

The  first  instruction  to  be  executed  is  "LD  BC,  (MPRAD)'V  The 
contents  of  memory  location  MPRAD  is  loaded  into  registers  B  and  C. 
a  has  been  assumed  that  MPR  is  equal  to  3,  i.e.,  "0000001 1 ",  After  ex- 
ecution of  this  instruction,  the  contents  of  register  C  have  been  set  to 
"3".  Note  that  this  instruction  will  also  result  in  loading  register  B  with 
whatever  followed  MPR  in  the  memory.  However,  the  next  instruction 
in  the  program  will  take  care  of  this  by  loading  register  B  with  "8",  as 
shown  in  Figure  3.21.  Note  that,  at  this  point,  the  contents  of  D  and  E 
and  H  and  L  are  still  undefined,  and  this  is  indicated  by  dashes.  The  LD 
instruction  does  not  condition  the  carry  bit,  so  that  the  contents  of  the 
carry  bit  C  are  undefined.  This  is  also  indicated  by  a  dash. 


LABEL 

1 - 

INSTRUCTION 

B 

C 

C 

D 

E 

H 

L 

MPY88 

LDBC,(0200} 
LD  B.  08 

00 
08 

03 
03 

Fig.  3,21:  Multiplication:  After  Two  Instructions 


The  situation  after  the  execution  of  the  first  five  mstructions  of  the 
program  (just  before  the  MULT)  is  shown  m  Figure  3.22. 
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LABEL 

INSTRUCTION 

B 

C 

C 

D 

E 

H 

L 

MPY88 

LD  BC,{0200) 

00 

03 

LD  B.  08 

08 

03 

- 

LD  DE,(0202) 

08 

03 

00 

05 

LDD,  00 

08 

03 

00 

05 

LD  HL,0000 

08 

03 

00 

05 

00 

00 

Fig.  3.22:  MuUipIication:  After  Five  Instructions 


The  SRL  instruction  will  perform  a  logical  shift  right,  and  the  right- 
most bit  of  MPR  will  fall  into  the  carry  bit.  You  can  see  in  Figure  3.23 
that  the  contents  of  MPR  after  the  shift  is  "0000  0001 The  carry  bit  C 
is  now  set  to  "I".  The  other  registers  are  unchanged  by  this  operation. 
Please  continue  to  fill  out  the  chart  by  yourself. 

A  second  iteration  is  shown  at  the  end  of  this  chapter  in  Fig.  3 .41 . 


LABEL 

INSTRUCTION 

8 

C 

C 

D 

E 

H 

L 

MPY88 

LD  BC,{0200) 

00 

03 

LD  B,  08 

08 

03 

LDDE,{0202) 

08 

03 

00 

05 

LDD,00 

08 

03 

00 

05 

LD  HL.OOOO 

08 

03 

00 

05 

00 

00 

MULT 

SRLC 

08 

01 

1 

00 

05 

00 

00 

JR  NC0114 

08 

01 

1 

00 

05 

00 

00 

ADD  HLDE 

08 

01 

0 

00 

05 

00 

05 

NOADD 

SLAE 

08 

01 

0 

00 

OA 

00 

05 

RLD 

08 

01 

0 

00 

OA 

00 

05 

DECS 

07 

01 

0 

00 

OA 

00 

05 

JP  NZ.OIOF 

07 

01 

0 

00 

OA 

00 

05 

Fig.  3.23:  One  Pass  Through  The  Loop. 
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A  complete  listing  showing  the  contents  of  all  the  Z80  registers  and 
the  flags  is  shown  in  Fig.  3.39  at  the  end  of  this  chapter  for  the  complete 
multiplication.  A  hex  or  decimal  listing  is  shown  in  Fig,  3.40. 

Programming  AHernatives 

The  program  that  we  have  just  developed  could  have  been  written. in 
many  other  ways.  As  a  general  rule,  every  programmer  can  usually  find 
ways  to  modify,  and  often  improve,  a  program.  For  example,  we  have 
shifted  the  multiplicand  left  before  adding.  It  would  have  been  mathe- 
matically equivalent  to  shift  the  resuh  one  position  to  the  right  before 
adding  it  to  the  multiplicand.  As  a  matter  of  fact,  this  is  an  interesting 
exercise! 

Exercise  3,19:  Write  an  8  x  8  multiplication  program  using  the  same 
algorithm,  but  shifting  the  result  one  position  to  the  right  instead  of 
shifting  the  multiplicand  by  one  position  to  the  left.  Compare  it  ,(o  the 
previous  program,  and  determme  whether  this  different  approach 
would  be  faster  or  slower  than  the  preceding  one.  The  speeds  of  the  Z80 
instructions  are  given  in  the  next  chapter. 

Improved  Multiplication  Program 

The  program  that  we  have  just  developed  is  a  straightforward  trans- 
lation of  the  algorithm  to  code.  However,  effective  programming  re- 
quires close  attention  to  detail,  and  the  length  of  the  program  can  often 
be  reduced  or  its  execution  speed  can  be  improved.  We  are  now  going  to 
study  alternatives  designed  to  improve  this  basic  program. 

Step  / 

A  first  possible  improvement  lies  in  the  better  utilization  of  the  Z80 
instruction  set.  The  second-to-lasi  instruction  as  well  as  the  preceding 
one  can  be  replaced  by  a  single  instruction: 

DJNZ  LOOP 

This  is  a  special  Z80  "automated  jump"  which  decrements  the  B  register 
and  branches  to  a  specified  location  if  it  is  not  "0",  To  be  absolutely 
correct,  the  instruction  is  not  completely  identical  to  the  previous  pair 

DEC  B 

JP  NZ,  MULT 
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ffOr  !t  specifies  a  displacement,  and  one  can  only  jump  witiiin  the  range 
of  -  126  to  +  129.  However,  we  must  here  jump  to  a  location  which  is 
only  a  few  bytes  away,  and  this  improvement  is  legitimate.  The 
resulting  program  is  shown  in  Figure  3.24  below: 


MPYSSB  LD  DE,  (MPDAD) 

LD  BC,  (MPRAD) 

LD  B,8 

LD  HL.  0 

MULT      SRL  C 

JR  NC,  NOADD 

ADD  HL.  DE 

NOADD   SLA  E 

RL  D 

DJNZ  MULT 

LD  (RESAD),  HL 
RET 


BIT  COUNTER 


Fig.  3.24:  Improved  Multiply,  Step  1 

Step  2 

in  order  to  improve  this  muitiplication  program  further,  we  will 
observe  thai  three  different  shift  operations  are  used  in  the  initial  pro- 
gram of  Figure  3.13.  The  multiplier  is  shifted  right,  then  the  multipli- 
cand MFD  Is  shifted  left,  in  two  operations,  by  first  shiftmg  register  E 
left,  then  rotating  register  D  to  the  left.  This  is  time-consuming.  A  stan- 
dard programming  "trick"  used  in  the  case  of  multiplication  is  based 
on  the  followmg  observation:  every  time  that  the  multiplier  is  shifted  by 
one  bit  position,  another  bit  position  becomes  available  in  the  multi- 
plier register.  For  example,  assuming  that  the  multiplier  shifts  right  (in 
the  previous  example),  a  bit  position  becomes  available  on  the  left. 
Simultaneously,  it  can  be  observed  that  the  first  partial  product  (or 
"result")  will  use,  at  most,  9  bits.  If  a  single  register  had  been  allocated 
to  the  result  in  the  beginning  of  the  program,  we  could  then  use  the  bit 
position  that  has  been  vacated  by  the  multiplier  to  store  the  ninth  bit  of 
the  result. 

After  the  next  shift  of  the  MPR,  the  size  of  the  partial  product  will  be 
increased  by  just  one  bit  again.  In  other  words,  a  single  register  can  be 
reserved  intially  for  the  partial  product,  and  the  bit  positions  which  are 
being  freed  by  the  multiplier  can  then  be  used  as  the  MPR  is  being 
shifted.  In  order  to  improve  the  program,  we  are  therefore  going  to 
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assign  MPR  and  RES  £o  a  register  pair,  ideally,  they  should  be  shifted 
together  in  a  single  operation.  Unfortunately,  the  ZSO  shifts  only  S-bit 
registers  at  a  time.  Like  most  other  8-bit  microprocessors,  it  has  no  in- 
struction that  allows  shifting  16  bits  at  a  time. 

However,  another  trick  can  be  used.  The  ZSO  {like  the  8080)  is 
equipped  with  special  i 6-bit  add  instructions  that  we  have  already  used. 
Provided  that  the  multiplier  and  the  result  are  stored  in  the  register  pair 
H  and  L,  we  can  use  the  instruction: 

ADD  HL,  HL 

which  adds  the  contents  of  H  and  L  to  itself.  Adding  a  number  to 
itself  IS  doubhng  it.  Doubling  a  number  in  the  binary  system  is  equiva- 
lent to  a  left  shift.  We  have  just  obtained  a  16-bit  shift  in  a  single  in- 
struction. Unfortunately,  the  shift  occurs  to  the  left  when  we  would  like 
It  to  occur  to  the  right.  This  is  not  a  problem. 

Conceptually,  the  MPR  can  be  shifted  either  left  or  right.  We  have 
used  a  right  shift  algorithm  because  this  is  the  one  which  is  used  in  or- 
dinary addition.  However,  it  does  not  necessarily  need  to  be  so.  The 
addition  operation  is  commutative,  and  the  order  can  be  reversed:  shif- 
ting the  MPR  to  the  left  is  just  as  valid. 

In  order  to  take  advantage  of  this  simulated  16-bit  shift,  we  will  have 
to  shift  the  MPR  to  the  left.  Therefore,  the  MPR  will  reside  in  register 
H  and  the  result  in  register  L.  The  resulting  register  configuration  is 
shown  in  Figure  3,25. 
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The  rest  of  the  program  is  essentially  identical  to  the  previous  one. 
The  resulting  program  appears  below: 


!VIUL88C 

LD 

HL,  {MPRAD^U 

LD 

L,  0 

LD 

DE,  (MPDAD) 

LD 

D,  0 

LD 

B.  8 

MULT 

ADD 

HL,  HL 

JR 

NC.  NOADD 

ADD 

HL,  DE 

NOADD 

DJNZ 

MULT 

LD 

(RESAD),  HL 

RET 

COUNTER 
SHIFT  LEFT 


Fig.  3.26:  Improved  Multiply,  Step  2 

When  comparmg  this  program  to  the  previous  one,  ii  can  be  seen  that 
the  length  of  the  multiplication  loop  (the  number  of  instructions  be- 
tween MULT  and  the  jump)  has  been  reduced.  This  program  has  been 
written  in  fewer  instructions  and  this  will  usually  result  m  faster  execu- 
tion. Thi-s  shows  the  advantage  of  selecting  the  correct  registers  to  con- 
tam  the  information. 

A  straightforward  design  will  generally  result  in  a  program  that 
works.  It  will  not  result  in  a  program  that  is  opiiimzed.  It  is  therefore 
important  to  understand  and  use  the  available  registers  and  instructions 
in  the  best  possible  way.  These  examples  illustrate  a  rational  approach 
to  register  selection  and  instruction  selection  for  maximum  efficiency. 

Exercise  3.20:  Compute  the  speed  of  a  imiltiplkatioii  operation  using 
this  last  program.  Assume  that  a  branch  will  occur  m  50%  oj  the  cases. 
Look  up  the  number  of  cycles  required  by  every  instruction  in  the  uide.x 
section.  Assume  a  clock  rale  of  2  MHz  (one  cycle  =  2  us). 

Exercise  3.21:  Note  thai  here  we  have  used  the  register  pair  D  and  E  to 
contain  the  multiplicand.  How  would  the  above  program  be  changed  ij 
we  had  used  the  register  pair  B  and  C  instead?  (Hint:  this  would  re- 
quire a  modification  at  the  end.) 

Exercise  3.22:  Wliy  did  we  have  to  bother  zeroing  register  D  when 
loading  MPD  info  E? 

Finally,  let  us  address  a  detail  which  may  look  irritating  to  the  pro- 
grammer who  is  not  yet  familiar  with  the  Z80.  The  reader  will  have 
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noticed  that,  in  order  to  load  MPD  into  E  from  the  memory,  we  had  to 
load  both  registers  D  and  E  at  the  same  time  from  a  memory  address. 
This  is  because,  unless  the  address  is  contained  in  registers  H  and  L, 
there  is  no  way  to  fetch  a  single  byte  directly  and  load  it  into  register  E. 
This  is  a  feature  carried  over  from  the  early  8008,  which  had  no  direct 
addressing  mode.  The  feature  was  carried  forward  into  the  8080,  with 
some  improvements,  and  improved  still  further  in  the  Z80,  where  it  is 
possible  to  fetch  16  bits  directly  from  a  given  memory  address  (but  not 
8  bits  -  except  toward  register  A). 

Now,  having  solved  this  possible  mystery,  let  us  execute  a  more 
complex  multiplication. 


A 16  X 16  Multiplication 

in  order  to  put  our  newly  acquired  skills  to  a  test,  we  \Vii!  multiply 
two  16-bit  numbers.  However,  we  will  assume  that  the  result  requires 
only  16  bits,  so  that  it  can  be  contamed  in  one  of  the  register  pairs. 

The  result,  as  in  our  first  multiplication  example,  is  contained  in 
registers  H  and  L  (see  Figure  3.27).  The  multiplicand  MPD  is  contained 
in  registers  D  and  E, 


COUNTER 


MPR,  HIGH 


 r '  ■■ 

MPD 


MPR,  tow  — 1 


 —  ,  _ 

RESULT 

3 

Fig.  3.27:  16  X  16  Maltiply— The  Registers 
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!i  would  be  icmpKng  to  deposii  a  muliiplier  mio  register  B  and  C. 
However,  if  we  want  to  take  advantage  of  the  DJNZ  in-struciion, 
register  B  must  be  allocated  to  the  counter.  As  a  result,  half  of  the 
multiplier  wilt  be  in  register  C,  and  the  other  half  ni  register  A  (see 
Figure  3,27).  The  mulEtplication  program  appears  below; 


MULI6 

LD 

A,  (MPRAD  -f-  1) 

MPR,  HIGH 

LD 

C,  A 

LD 

A,  (MPRAD) 

MPR,  LOW 

LD 

B,  16 

COUNTER 

LD 

DE,{MPDAD) 

MPD 

LD 

HL,  0 

MULT 

SRL 

C 

RIGHT  SHIFT  MPR, 

HIGH 

RRA 

ROTATE  RIGHT  MPR, 

LOW 

JR 

NC,  NOADD 

TEST  CARRY 

ADD 

HL,  DE 

ADD  MPD  TO  RESULT 

NOADD 

EX 

DE,  HL 

ADD 

HL,  HL 

DOUBLE  -  SHIFT  MPD 

LEFT 

EX 

DE,  HL 

DJNZ 

MULT 

RET 

Fig.  3.28:  16  X  16  Multiplication  Program 


The  program  is  analogous  to  those  we  have  developed  before.  The 
first  six  instructions  (from  label  MUL16  to  label  MULT)  perform  the 
initialization  of  registers  with  the  appropriate  contents.  One  complica- 
tion is  introduced  here  by  the  fact  that  the  two  halves  of  MPR  must  be 
loaded  m  separate  operations,  it  is  assumed  that  MPRAD  points  to  the 
low  part  of  the  MPR  in  the  memory,  followed  m  the  ne.xt  sequential 
memory  location  by  the  high  part,  (Note  that  the  reverse  convention 
can  be  used,)  Once  the  high  part  of  MPR  has  been  read  into  A,  it  must 
be  transferred  into  C: 

LD       A,  (MPRAD  +  1) 
LD       C,  A 

Finally,  the  low  part  of  MPR  can  be  read  directly  into  the  accumulator; 
LD       A,  (MPRAD) 
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The  rest  of  the  registers,  B,  D,  E,  H,  and  L  are  initialized  as  usual: 

LD       B,  16 

LD       DE,  (MPDAD) 

LD       HL,  0 

A  i6-bit  shift  must  be  performed  on  the  multiplier.  It  requires  two 
separate  shift  or  rotate  operations  on  registers  C  and  A: 

MULT      SRL  C 
RRA 

After  the  16-bit  shift,  the  right-most  bit  of  the  MPR,  i.e.,  the  LSB,  is 
contained  in  the  carry  bit  C  where  it  can  be  tested: 

JR        NC,  NOADD 

As  usual,  the  multiplicand  is  not  added  to  the  result  if  the  carry  bit  is 
"0",  and  is  added  to  the  result  if  the  carry  bit  is  "1": 

ADD     HL,  DE 

Next,  the  multiplicand  MPD  must  be  shifted  by  one  position  to  the  left. 

However,  the  Z80  does  not  have  an  instruction  which  will  shift  the 
contents  of  register  D  and  E  simultaneously  to  the  left  by  one  bit  posi- 
tion, and  It  can  also  not  add  the  contents  of  D  and  E  to  itself.  The  con- 
tents of  D  and  E  will  therefore  first  be  transferred  into  H  and  L,  then 
doubled,  and  transferred  back  to  D  and  E.  This  is  accomplished  by  the 
next  three  instructions: 

NOADD  EX  DE,  HL 
ADD  HL.  HL 
EX       DE,  HL 

Finally,  the  counter  B  is  decremented  and  a  jump  occurs  to  the  begin- 
ning of  the  loop  as  long  as  it  does  not  decrement  to  "0": 

DJNZ  MULT 

As  usual,  it  is  possible  to  consider  other  register  allocations  which  may 
(or  may  not)  result  in  shorter  codes; 

Exercise  3.23:  Load  the  multiplier  into  registers  B  and  C.  Place  the 
counter  m  A.  Write  the  corresponding  multiplication  program  and 
discuss  the  advantages  or  disadvantages  of  this  register  allocation. 
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Exercise  3.24:  Referring  lo  she  original  16-bil  nntltiplicatiuii  program 
of  Figure  3.28,  can  you  propose  a  way  lo  shift  the  MPD,  contained  in 
registers  D  and  E,  without  transferring  it  into  registers  H  and  L? 

lixerci.se  3.25:  VVnie  a  l6-by-l6  nmliipliculion  pragniiii  which  deiecis 
the  fact  that  the  result  has  more  than  16  bits.  This  is  a  simple  miprave- 
nient  of  our  (msic  program. 

E.Kercise  3.26:  Wnie  a  I6~by-16  miiliiplicution  program  wtih  a  32-bil 
result,  Tlie  suggested  register  allocation  appears  in  Figure  3.29, 
Remember  tfiat  t/te  initial  result  after  the  first  addition  m  the  loop  will 
require  only  16  bits,  and  that  the  multiplier  will  free  one  bii  for  each 
subsequent  iieraiion. 


— j — 

MPD 


E 


RES 


RESULT 
AFTER 

MULTIPLICATION 


Fig.  3.29:  16  x  16  Multiply  with  32-Bil  Resull 


Let  us  now  examine  the  last  usuai  anlhmelic  operation,  ihe  division. 

BINARY  DIVISION 

The  algorithm  for  binary  division  is  analogous  to  the  one  which  has 
been  used  for  the  multiplication.  The  divisor  is  successively  subtracted 
from  the  high  order  bits  of  the  dividend.  After  each  subtraction,  the 
result  is  used  instead  of  the  initial  dividend.  The  value  of  the  quotient  is 
simultaneously  increased  by  1  every  time.  Eventually,  the  result  of  ihe 
subtraction  is  negative.  This  is  called  an  overdraw.  One  must  ihen 
restore  the  partial  result  by  adding  the  divisor  back  to  it.  Naturally,  the 
quotient  must  be  simultaneously  decremented  by  I.  Quotient  and  divi- 
dend are  then  shifted  by  one  bit  position  lo  the  left  and  ihe  algorithm  is 
repeated.  The  flow-chart  is  shown  in  Figure  3.30. 

The  method  just  described  is  called  the  restoring  method.  A  variation 
of  this  method  which  yields  an  improved  speed  of  execution  is  called  the 
non-restoring  method. 
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Quotient  =  o 

SHIFTCOUNTEB  =  4 


1  V 


SHtfT  LIFT 
DiVIDEND 
IWITHBUADiNGO'l) 
AND  QUOTIENT 


TRIAL  SUBTRACT: 
lECT  |DiVIDEND).DIVISOR 


QUOTIENT 

=QUOTI£Nf +  1 

COUNTER 

=  COUMTER- 1 

RESTORE: 
ADD  DIVISOR 
 '  


END  (REMAINDER  !N  l£R  (DIVIDENOI 

Fig.  3.30:  8-BiC  Binary  Division  Fiowcharl 


8    COUNTER , 


oj  Dvs  ;  o;;;3e 


! 

DiVIDENO/QUOTIENT 

I 

1_~ 

Fig.  3.31;  16/8  Division— The  Registers 
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Id-by-S  Division 

As  an  example,  lei  us  here  examine  a  16-by-8  division,  which  will 
yield  an  8-bit  quotient  and  an  8-bit  remainder  dividend.  The  register 
allocation  is  shown  in  Figure  3.31, 


The  program  appears  below: 


DIV168 

LD 

A,  (DVSAD) 

LOAD  DIVISOR 

LD 

D,  A 

INTO  D 

LD 

E,  0 

LD 

HL.  (DVDAD) 

LOAD  16-BIT  DIVIDEND 

B,  8 

INITIALIZE  COUNTER 

DIV 

XOR 

A 

CLEAR  C  BIT 

SBC 

HL,  DE 

DIVIDEND  -  DIVISOR 

INC 

HL 

QUOTIENT  =  QUOTIENT  +  i 

JP 

P,  NOADD 

TEST  IF  REMAINDER 
POSITIVE 

ADD 

HL,  DE 

RESTORE  IF  NECESSARY 

DEC 

HL 

QUOTIENT  =  QUOTIENT  -  i 

NOADD  ADD 

HL.  HL 

SHIFT  DIVIDEND  LEFT 

DJNZ 

DIV 

LOOP  UNTIL  B  =  0 

RET 


Fig.  3.32:  16/8  Division  Program 


The  first  five  instructions  in  the  program  load  the  divisor  and  the  divi^- 
dend  respectively  mto  the  appropriate  registers.  They  also  initialize  the 
counter,  in  register  B,  to  the  value  8.  Note  again  that  register  B  is  a  pre- 
ferred location  for  a  counter  if  the  specialized  Z80  instruction  DJNZ  is 
to  be  used: 

DIV  168     LD       A,  (DVSAD) 
LD       D,  A 
LD       E,  0 
LD       HL,  (DVDAD) 
LD       B,  8 

Next,  the  divisor  is  subtracted  from  the  dividend.  Since  an  SBC  in- 
struction must  be  used  {there  is  no  16-bu  subtract  without  carry),  the 
carry  must  be  set  to  the  value  "0"  before  subtracting.  Thi^  can  be  ac- 
complished in  a  number  of  ways.  The  carry  can  be  cleared  by  perform- 
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ing  instructions  such  as: 

XOR  A 
AND  A 
OR  A 

Here,  an  XOR  is  used: 

DIV          XOR  A 

The  subtraction  can  then  be  performed: 

SBC      HL,  DE 

It  is  anticipated  that  the  subtraction  will  be  successful,  i.e.,  that  the  re- 
mainder will  be  positive.  This  is  called  the  "trial  subtract"  step  (refer  to 
the  flowchart  of  Figure  3.30).  The  quotient  is  therefore  incremented  by 
one.  If  the  subtraction  has  in  fact  failed  (i.e.,  if  the  remainder  is 
negative),  the  quotient  will  have  to  be  decremented  by  one  later  on; 

INC  HL 

The  result  of  the  subtraction  is  then  tested: 

JP        P,  NOADD 

if  the  remainder  is  positive  or  zero,  the  subtraction  has  been  successful, 
and  it  is  not  necessary  to  store  it.  The  program  jumps  to  address 
NOADD.  Otherwise,  the  current  dividend  must  be  restored  to  its 
previous  value,  by  adding  the  divisor  back  to  it,  and  the  quotient  must 
be  decremented  by  one.  This  is  performed  by  the  next  instructions: 

ADD     HL.  DE 
DEC  HL 

Finally,  the  resulting  dividend  is  shifted  left,  in  anticipation  of  the 
next  trial  subtract  operation.  Finally,  the  B  counter  is  decremented  and 
tested  for  the  value  "0".  As  long  as  B  is  not  zero,  this  loop  is  executed: 

NOADD   ADD    HL,  HL 
DJNZ  DIV 
RET 

Exercise  3.27:  Verify  (lie  operation  of  (Ins  division  program  by  hand, 
by  filling  out  (he  table  of  Figure  3.33,  as  in  Exercise  3.18  for  the  luulti- 
plicadon.  Note  that  the  contents  of  D  need  not  be  entered  on  the  form 
of  Figure  3.33,  since  they  are  never  modified. 
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^NSjaUCllON 

& 

H 

\ 

Fig.  3.33:  Form  for  Division  Program 


g-Bit  Division 


The  following  program  uses  a  restoring  method,  and  leaves  a  com- 
plemented quotient  in  A,  It  divides  8  bits  by  8  bits  (unsigned). 

E  IS  DIVIDEND 
C  IS  DIVISOR 
A  IS  QUOTIENT 
B  IS  REMAINDER 


D1V88  XOR 
LD 

LOOP88  RL 

RLA 
SUB 
JR 

ADD 

DJNZ 

LD 

LD 

RLA 

CPL 

RET 


A  CLEAR  ACCUMULATOR 

B,  8  LOOP  COUNTER 

E  ROTATE  CY  INTO  ACC- 

DIVIDEND 

CY  WILL  BE  OFF 
C  TRIAL  SUBTRACT  DIVISOR 

NC,  $  +  3         SUBTRACT  OK 

A,  C  RESTORE  ACCUM,  SET  CY 
LOOP88 

B.  A  PUT  REMAINDER  IN  B 
A,  E                GET  QUOTIENT 

SHIFT  IN  LAST  RESULT  BIT 

COMPLEMENT  BITS 


Noie:  she  "S"  symbol  in  the  sixth  instruction  represents  the  value  of  the 
program  counter. 
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Non  Restoring  Division 

The  followtng  program  performs  a  !6-bit  by  !5-bu  integer  division, 
usmg  a  non-ressormg  technique.  IX  pomls  to  the  dividend,  lY  to  the 
divisor  (not  zero),  (see  Figure  3.34.). 


A       DVD,  HI 


B      COUNTER         DVD,LO  C 


DiVISOR 


H  REM 

jX  DVD  ADDRESS 

)y|  DVS  ADDR 


Fig.  3.34:  Non-Restoring  Division— The  Registers 

Register  B  is  used  as  a  counter,  initially  set  to  16. 

A  and  C  contain  tlie  dividend. 

D  and  E  contain  the  divisor. 

H  and  L  contain  the  result. 

The  16-bit  dividend  is  shifted  left  by: 

RL  C 

RLA 

The  remainder  is  shifted  left  by: 

The  final  quotient  is  left  in  B,  C,  with  the  remainder  in  HL.  The 
program  follows. 
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DIV16 

LD 

LD 

C  flXI 

LD 

LD 

F  HYI 

LD 

A,  D 

OR 

E 

(DIVISORt  HIGH  OR 

fnivisoR^  i  ow 

JR 

7  FRROR 

THFCK  FOR  DIVISOR  = 

7FRO 

LD 

A,  B 

GET  (DVD)  HI 

LD 

HL,  0 

CI  EAR  RESULT 

LD 

R  ifi 

Lt^    1  U 

COUNTER 

TRiALSB  RL 

\_- 

ROTATE  RFSUI  T  +  ACC 

I  FFT 

RI  A 

ADr 

T  prTT  SHIFT   NFVFR  SFTS 

TARRY 

SBC 

MINUS  niVISOR 

NULL 

CCF 

RFSI II  T  RiT 

in 

ArT'liMIil  ATOP 

DJNZ 

rOUNTFR  7FRO*' 

JP 

DONE 

RESTOR 

RL 

C 

ROTATE  RESULT  ACC 

LEFT 

RLA 

ADC 

Ht  HI 

AS  AROVF 

AND 

A 

ADC 

HI  DF 

RFSTORF  HV  AnniNir;  nv<: 

JR 

C  PTV 

JR 

RFSI  11  T  7FRn 

1\  1^      KJ  i_  i     Z_  i_  1\ 

NGV 

DJNZ 

RESTOR 

COUNTER  ZERO"' 

DONE 

RL 

O  M I  r  1   1  IN  KEo  U  L.  1   D 1  1 

RLA 

ADD 

HL.  DE 

CORRECT  REMAINDER 

LD 

B,  A 

QUOTIENT  IS  IN  B,  C 

RET 
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Exercise  3.28:  Compare  ihe  previous  program  to  Uie  following  one,  tis- 
mg  a  restoring  lechnique: 

DIVIDEND  IN  AC 
DIVISOR  IN  DE 
QUOTIENT  IN  AC 
REMAINDER  IN  HL 

DiV16 
LOOP  1 6 


ML,  U 

ri  FAR  AmJMllI  ATOR 

LD 

B,  10 

RL 

C 

ROT  ACC-RESULT  LEFT 

RLA 

ADC 

HL,  HL 

LEFT  SHIFT 

SBC 

HL,  DE 

TRIAL  SUBTRACT  DIVISOR 

JR 

NC,  S  +  3 

SUB  WAS  OK 

ADD 

HL,  DE 

RESTORE  ACCUM 

CCF 

CALC  RESULT  BIT 

DJNZ 

LOOP  16 

COUNTER  NOT  ZERO 

RL 

C 

SHIFT  IN  LAST  RESULT  BIT 

RLA 

RET 

Note:  The  symbol  "S"  means  "curreni  location"  (eighth  mstruction). 


LOGICAL  OPERATIONS 

The  other  class  of  instructions  which  can  be  executed  by  the  ALU  in- 
side the  microprocessor  is  the  set  of  logical  instructions.  They  mclude: 
AND,  OR  and  exclusive  OR  (XOR).  In  addition,  one  can  also  mclude 
here  the  shift  and  rotate  operations  which  have  already  been  utilized, 
and  the  comparison  instruction,  called  CP  for  the  Z80.  The  individual 
use  of  AND,  OR,  XOR,  will  be  described  in  Chapter  4  on  the  instruc- 
tion set. 

Let  us  now  develop  a  brief  program  which  will  check  whether  a  given 
memory  location  called  LOC  contains  the  value  "0",  the  value  "1",  or 
something  else. 

The  program  will  introduce  the  comparison  instruction,  and  perform 
a  series  of  logical  tests.  Depending  on  the  result  of  the  comparison,  one 
program  segment  or  another  will  be  executed. 
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The  program  appears  below: 


LD 

A,  (LOC) 

READ  CHARACTER  IN 

LOC 

CP 

OOH 

COMPARE  TO  ZERO 

JP 

Z,  ZERO 

IS  IT  A  0? 

CP 

OIH 

COMPARE  TO  ONE 

JP 

Z.  ONE 

NONEFOUND  ,. 

ZERO 

ONE 

The  first  instruction:  "LD  A,  (LOC)"  reads  the  contents  of  memory 
location  LOC,  and  loads  it  into  the  accumulator.  This  is  the  character 
we  want  to  test.  It  is  compared  to  the  value  0  by  the  following  instruc- 
tion: 

CP  OOH 

This  instruction  compares  the  contents  of  the  accumulator  to  the  hex- 
adecimal value  "00",  i.e.,  the  bit  pattern  "0000  0000":  This  compari- 
son instruction  will  set  theZ  bit  in  the  flags  register  to  the  value  "1",  if 
It  succeeds.  This  bit  can  then  be  tested  by  the  next  instruction; 

JP        Z,  ZERO 

The  jump  instruction  tests  the  value  of  the  Z  bit.  if  the  comparison  suc- 
ceeds, the  Z  bit  has  been  set  to  one,  and  the  jump  will  succeed.  The  pro- 
gram will  then  jump  to  the  address  ZERO,  if  the  test  fails,  then  the  next 
sequential  instruction  will  be  executed; 

CP  OIH 

Similarly,  the  foilowing  jump  instruction  will  branch  to  location  ONE 
if  the  comparison  succeeds,  if  none  of  the  comparisons  succeed,  then 
the  instruction  at  location  NONEFOUND  will  be  executed. 

JP        Z,  ONE 
NONEFOUND  .. 
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This  program  was  iniroduced  to  demonsSraSe  the  value  of  the  com- 
parison insiructton  foliowed  by  a  jump.  This  combination  will  be  used 
in  many  ol'  the  rollovving  programs. 

lixercisc  3.29:  Refer  fo  ihe  definiiion  oj  the  LD  A,  (LOO  instruction  in 
ihe  next  chapter,  t'xaiiiine  the  effect  of  this  insiniciion  on  the  flags,  if 
any.  Is  the  second  instruction  of  i his  program  necessary  (CP  OOH)? 

liKercixe  3. JO:  Wnle  the  program  which  will  read  tlie  contents  of 
incinory  location  "24"  and  branch  to  an  address  called"STA 'iflliere 
wax  a  "*"//;  memory  location  24.  The  l)il  pattern  for  a  in  iiinary 
notation  will  l}e  assumed  to  be  represented  by  "QOlOlOlO". 


INSTRUCTION  SUMMARY 

Wc  have  now  suidied  most  of  ihc  iiiiporians  mstruclions  of  the  Z80 
by  using  thcni.  We  have  transferred  values  between  the  memory  and  the 
registers.  Wc  have  performed  arithmetic  and  logical  operations  on  such 
data.  We  have  tested  it,  and  depending  on  the  results  of  these  tests, 
have  executed  various  portions  of  the  program,  in  particular,  special 
"automated"  Z80  instructions  such  as  DJNZ  have  been  used  to  shorten 
programs.  Other  automated  instructions;  LDDR,  CPIR,  INIR  will  be 
introduced  throughout  the  remainder  of  this  book. 

Full  u.se  ha.s  been  made  of  spccsal  Z80  features,  such  as  16-bit  regi.ster 
instructions  to  simplify  the  programs,  and  the  reader  should  be  careful 
not  to  use  these  programs  on  an  8080;  ihey  have  been  optimized  ior  the 
Z80. 

We  have  aiso  introduced  a  structure  called  a  loop.  Another  impor- 
tant programming  structure  wiil  be  introduced  now:  the  subroutine. 

SUBROUTINES 

In  concept,  a  subroutine  is  simply  a  block  of  instructions  which  has 
been  given  a  name  by  the  programmer.  From  a  practical  standpomi,  a 
subrouunc  must  start  with  a  special  instruction  called  a  siibroiiiine 
declaration,  which  identifies  it  as  such  for  the  assembler.  It  is  also  ter- 
minated by  another  .special  instruction  called  a  reluni.  Let  us  first  il- 
lustrate ihc  use  of  a  subroutine  m  a  program  in  order  to  demonstrate  its 
value.  Then,  we  will  examine  how  it  is  actually  implemented. 
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Fijj.  3.35:  Stihroulinc  Calls 

The  use  o!'  a  subroutine  i.s  illusiraled  m  Figure  3.35.  The  main  pro- 
gram appears  on  ihc  lefi  ol"  she  iHusirauon.  The  subroutmo  !s  shown 
symbolically  on  the  righl.  Lei  us  e.xamme  ihe  subrouune  mechanism. 
The  lines  of  Ihc  mam  program  are  cxccuicd  successively  until  a  new  in- 
struction "CALL  SUB"  IS  met.  This  special  instruction  is  ihe 
subrouiine  call  and  results  in  a  transfer  to  the  subroutine.  Thi.s  means 
that  the  next  instruction  to  be  executed  after  the  CALL  SUB  is  the  first 
instruction  within  the  subroutine.  This  i.s  illu.siraied  by  arrow  I  on  the 
illustration. 

Then,  the  subprogram  withm  the  subroutine  executes  just  like  any 
other  program.  We  will  assume  thai  the  subroutine  does  not  contain 
any  other  calls.  The  last  insiruciioii  of  this  subroutine  is  a  RETURN. 
This  !s  a  special  instruction  which  will  cause  a  return  to  the  mam  pro- 
gram. The  next  instruction  to  be  executed  after  the  RHTURN  is  the  one 
following  the  CALL  SUB  in  the  main  program.  This  is  illustrated  by  ar- 
row 3  on  the  illustration.  Program  execution  contmues  then,  as  il- 
lustrated by  arrow  4, 

lii  the  body  of  the  main  program  a  second  CALL  SUB  appears.  A 
new  iransfcr  occurs,  shown  by  arrow  5.  This  means  that  the  body  of  the 
subruiitine  ss  again  executed  following  the  CALL  SUB  mstruction. 

Whenever  the  RLTURN  within  the  subroutine  ls  encountered,  a 
return  occurs  to  the  instruction  following  the  CALL  SUB  in  question. 
This  is  illustrated  by  arrow  1.  Following  the  return  to  the  mam  pro- 
gram, program  execution  proceeds  normally,  as  illustrated  by  arrow  8. 

The  effect  of  the  two  special  instructions  CALL  SUB  and  RETURN 
should  now  be  clear.  What  is  the  value  of  ihc  subroutine  mechanism? 

The  essential  value  of  the  subrouiinc  is  that  i(  can  be  called  from  any 
number  of  points  in  the  mam  program,  and  used  repeatedly  wiiliout 
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rewniin^  it.  A  first  advantage  is  thai  this  approach  saves  memory 
space,  since  there  is  no  need  lo  rewnie  the  subroutine  every  iimc.  A  se- 
cond advantage  is  thai  the  programmer  can  design  a  specific  subroutine 
only  once  and  then  use  ii  repeatedly.  This  is  a  signii'icanl  simpliHcanon 
in  program  design. 

Exercise  3.31:  What  ts  (he  tnain  disadvantage  of  a  subi  ouiine?  (Answer 
foliows.) 

The  disadvantage  oT  the  subrouime  should  be  clear  just  by  cxamming 
ihc  How  of  execution  between  the  main  program  and  (he  subroutme.  A 
subrouime  results  m  a  slower  exeaiHon,  snice  extra  instructions  must 
be  executed:  the  CALL  SUB  and  the  RETURN. 

[mplcmcniation  of  the  Subroutine  Mechanism 

Wc  will  examine  here  how  the  two  special  mstruciions,  CALL  SUB 
and  RETURN,  are  implemented  internally  within  the  processor.  The 
el't'ect  of  the  CALL  SUB  instruction  is  to  caii.se  the  next  Instruction  to 
be  fetched  at  a  new  address.  You  will  remember  (or  else  read  Chapter 
!  agam )  ihai  the  address  of  the  next  instruction  to  be  executed  In  a 
computer  is  contained  in  the  program  counter  (PCI.  This  means  ihat 
the  cffccl  of  the  CALL  SUB  is  to  subsiilute  new  contents  in  register  PC. 
lis  effect  IS  to  load  the  start  address  of  !he  subroutine  m  the  program 
counlcr.  Is  thai  really  siiffiaeni? 

To  answer  this  question,  let  us  consider  ihe  other  insii'uction  which 
has  !o  be  implemented:  the  RETURN.  The  RETURN  musi  cause,  as  its 
name  indicates,  a  return  to  the  instruction  that  follows  the  CALL  SUB, 
This  IS  po.s.sible  only  if  the  address  of  this  instruction  has  been  preserved 
somewhere.  This  address  happens  to  be  ihe  value  of  the  program 
counter  at  the  time  that  the  CALL  SUB  was  encouniered.  This  is 
because  the  progratn  counter  is  automat icaliy  incremenied  every  iimc  it 
!s  used  {read  Chapter  I  again).  This  is  precisely  the  address  thai  wc  want 
10  preserve,  so  ihat  we  can  later  perioriii  the  RETURN. 

The  next  problem  is:  where  can  we  save  this  return  address?  This  ad- 
dress must  be  saved  in  a  location  where  it  is  guaranteed  that  it  will  not 
be  erased. 

However,  let  us  now  consider  the  following  situation,  illustrated  by 
Figure  3.36.  In  this  example,  subroutine  I  contains  a  call  to  SUB2.  Our 
mechanism  should  work  in  this  ca.se  as  well.  Naturally,  there  might  even 
be  more  than  two  subroutines,  say  N  "nested"  calls.  Whenever  a  new 
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CALL  i.s  encountered,  the  mechanism  must  therefore  again  store  the 
program  counier.  This  implies  shai  we  need  at  ieast  2N  memory  loca- 
tions for  thss  mechanism.  Addilionally,  we  will  need  lo  return  from 
SUB2  first  and  SUBl  next.  In  other  words,  we  need  a  structure  which 
can  preserve  the  chronological  ordering  m  which  addresses  have  been 
saved. 

The  structure  has  a  name  and  has  already  been  introduced,  ll  is  the 
Slack.  Figure  3.38  shows  the  actual  conlenls  of  ihe  stack  during  suc- 
cessive subroutine  calls.  Let  us  look  at  the  mam  program  first.  At  ad- 
dress 100,  ihe  first  call  is  encountered:  CALL  SUBl.  We  will  assume 
that,  in  this  microproce.s-sor,  the  subroutine  call  uses  3  bytes  (RST  is  an 
exception).  The  next  sequential  address  is  therefore  not  "101",  but 
"103".  The  CALL  in.ssruciion  u.ses  addrcs.ses  "100",  "101",  "102"- 
Becau.se  the  control  unit  of  the  Z80  "knows"  that  it  is  a  3-byte  instruc- 
tion, the  value  of  the  program  counter,  when  the  call  has  been  com- 
pletely decoded,  will  be  "103".  The  effect  of  the  call  will  be  to  load  the 
value  "280"  in  the  program  counter.  "280"  is  the  starting  address  of 
SUBl. 


Fig.  3.36:  Nested  Calls 


We  are  now  ready  to  demonstrate  the  effect  of  the  RETURN  instruc- 
tion and  the  correct  operation  of  our  stack  mechanism.  Execution  pro- 
ceeds within  SUB2  until  the  RETURN  instruction  is  encountered  at 
time  3.  The  effect  of  the  RETURN  instruction  is  simply  to  pop  the  top 
of  the  slack  into  the  program  counter.  In  other  words,  the  program 
counter  is  restored  to  its  value  prior  to  the  entry  into  the  subroutine. 
The  lop  of  the  stack  in  our  example  is  "303".  Figure  3.38  shows  that,  at 
time  3,  value  "303"  has  been  removed  from  the  stack  and  has  been  put 
back  into  the  program  counter.  As  a  result,  instruction  execution  pro- 
ceeds from  address  "303".  At  time  4,  the  RETURN  of  SUBl  is  encoun- 
tered. The  value  on  top  of  the  stack  is  "103".  It  is  popped  and  is  in- 
stalled in  the  program  counter.  As  a  result,  program  execution  will  pro- 
ceed from  location  "103"  on  within  the  main  program.  This  is,  Indeed, 
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ihe  effect  that  we  wanted.  Figure  3.38  shows  that  at  time  4  the  stack  is 
again  empty.  The  mechanism  works. 

The  subroutine  cail  mechanism  works  up  to  the  maximum  dimension 
of  the  stack.  This  is  why  early  microprocessors  which  had  a  4-  or 
8-register  stack  were  essentially  limited  to  4  or  8  levels  of  subroutine 
calls. 

Note  that,  on  Figures  3.36  and  3.37,  the  subroutines  have  been 
shown  to  the  right  of  the  main  program.  This  is  only  for  the  clarity  of 
the  diagram.  In  reality,  the  subroulmes  are  typed  by  the  user  as  regular 
instructions  of  the  program.  On  a  sheet  of  paper,  when  producing  the 
listing  of  the  complete  program,  the  subroutines  may  be  at  the  begm- 
ning  of  the  text,  in  its  middle,  or  al  the  end.  This  is  why  they  are  pre- 
ceded by  a  subroutine  declaration:  they  must  be  identified.  The  special 
mstructions  tell  the  assembler  that  what  follows  should  be  treated  as  a 
subroutine.  Such  assembler  directives  will  be  discussed  in  Chapter  10. 

ADDBE55  ^^U^IN^ 


100 
!03: 


ISO 


(SUB  I ) 


Fig.  3.37:  The  Subroutine  Calls 
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Fig.  3.38:  Stack  vs.  Time 
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Z80  Subroutines 

The  basic  concepts  relating  to  subroutines  have  now  been  presented. 
It  has  been  shown  that  the  stack  is  required  in  order  to  implement  this 
mechanism.  The  Z80  is  equipped  with  a  16-bit  stack-pointer  register. 
The  stack  can  therefore  reside  anywhere  within  the  memory  and  may 
have  up  to  64K  (IK  =  1024)  bytes,  assuming  they  are  available  for  that 
purpose.  In  practice,  the  start  address  for  the  stack,  as  well  as  its  max- 
imum dimension,  will  be  defined  by  the  programmer  before  writing  his 
program,  A  memory  area  will  then  be  reserved  for  the  stack. 

The  subroutine-call  instruction,  in  the  case  of  the  Z80,  is  called 
CALL,  and  comes  jh  two  versions;  the  direci  or  uncondinonai  call, 
such  as  CALL  ADDRESS,  is  the  one  we  have  already  described.  In  ad- 
dition, the  Z80  is  equipped  with  a  conditional  call  instruction  which  will 
call  a  subroutine  if  a  condition  is  met.  For  example:  CALL  NZ,  SUB  I 
will  result  in  a  call  to  subroutine  I  if  the  Z  flag  is  zero  at  the  time  of  the 
test.  This  is  a  powerful  facility,  since  many  subroutine  calls  are 
conditional,  i.e,,  occur  only  if  some  specific  condition  is  met, 

CALL  CC,  NN  IS  executed  only  if  the  condition  specified  by  "C'C" 
IS  true.  CC  is  a  set  of  three  bits  (bits  3,  4,  and  5  of  the  opcode)  which 
may  specify  up  to  eight  conditions.  They  correspond  respectively  to  the 
four  nags  "Z",  "C",  "P/V",  "S"  oeing  either  zero  or  non-zero. 

Similarly,  two  types  of  return  instructions  are  provided:  RET  and 
RET  CC. 

RET  is  the  basic  return  instruction.  It  occupies  one  byte,  and  causes 
the  top  two  bytes  of  the  slack  to  be  re-installed  m  the  program  counter. 
It  is  unconditional. 

RET  CC  has  the  same  effect  except  that  it  is  executed  only  if  the  con- 
ditions specii'ied  by  CC  are  true.  The  condition  bits  are  the  same  as  lor 
the  CALL  instruction  just  described. 

Additionally,  two  specialized  types  of  return  are  available  which  are 
used  to  terminate  interrupt  routines:  RETI,  RETN.  They  are  described 
in  the  section  on  the  Z80  mstructions  as  well  as  in  the  section  on  inter- 
rupts. 

Finally,  one  more  specialized  mstruction  is  provided  which  is  analo- 
gous to  a  subroutine  call,  but  allows  the  program  to  branch  to  only  one 
of  eight  starting  locations  located  in  page  zero.  This  is  the  RST  P  in- 
struction. This  is  a  one-byte  instruction  which  automatically  preserves 
the  program  counter  in  the  stack,  and  causes  a  branch  to  the  address 
specified  by  the  three-bit  P  field.  The  P  field  corresponds  to  bits  3,  4 
and  5  of  the  insrtuction,  multiplied  by  eight. 
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In  other  words,  if  bits  3,  4,  5  are  "000" ,  the  jump  will  occur  to  loca- 
tion OOH.  \f  these  bits  are  "001",  the  branch  wiit  occur  to  08H,  etc.  up 
to  111,  which  will  cause  a  branch  to  location  38 H.  The  RST  instruction 
IS  very  efficient  in  terms  of  speed  since  it  is  a  single-byte  instruction. 
However,  it  can  jump  to  only  eight  locations,  in  page  0.  Additionally, 
these  addresses  m  page  0  are  only  eight  bytes  apart.  This  instruction  is  a 
carry-over  from  the  8080  and  was  extensively  used  for  mterrupts.  This 
will  be  described  in  the  interrupt  section.  However,  this  instruction  may 
be  used  for  any  other  purpose  by  the  programmer,  and  should  be  con- 
sidered as  a  possible  specialized  subroutine  call. 

Subroutine  Examples 

Most  of  the  programs  that  we  have  developed  and  are  going  to 
develop  would  usually  be  written  as  subroutines.  For  example,  the 
multiplication  program  is  likely  to  be  used  by  many  areas  of  the  pro- 
gram, in  order  to  facilitate  and  clarify  program  development,  it  is 
therefore  convenient  to  define  a  subroutine  whose  name  would  be,  for 
example,  MULT.  At  the  end  of  this  subroutine  we  would  simply  add 
the  instruction  RET. 

Exercise  3.32:  If  MULT  is  used  as  a  subrouline,  would  it  "damage" 
any  internal  flags  or  registers? 

Recursion 

Recursion  is  a  word  used  to  indicate  that  a  subroutine  is  calling  itself. 
If  you  have  understood  the  implementation  mechanism,  you  should 
now  be  able  to  answer  the  following  question: 

Exercise  3.33:  Is  it  legal  to  lei  a  subroutine  call  itself?  (In  other  words, 
will  everything  work  even  if  a  subroutine  calls  itself?)  If  you  are  not 
sure,  draw  the  stack  and  fill  II  with  tiie  successive  addresses.  Then,  look 
at  the  registers  and  memory  (see  Exercise  3.18)  and  determine  if  a  pro- 
blem exists. 

interrupts  will  be  discussed  in  the  input/output  chapter  (Chapter  6). 
All  returns  except  returns  from  interrupts  are  one- byte  instructions;  all 
calls  are  3- byte  instructions  (except  RST). 

E.xercise  3.34:  Look  at  the  execution  times  of  the  CALL  and  the  RET 
instructions  in  the  next  chapter.  Why  is  the  return  from  a  subrouline  so 
much  faster  limn  the  CALL?  (Hint:  if  the  answer  is  not  obvious,  look 
again  at  the  stack  implementation  of  the  subroutine  mechanism,  and 
analyze  the  internal  operations  that  must  be  performed.) 
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^t^li^  itsaR^  a  subroutine,  one  normally  expects  ihe  subroutine  to 
WSiIe  on  some  data.  For  example,  in  the  case  of  multiplication,  one 
wants  to  transmit  two  numbers  to  the  subroiiiiiie  which  will  perform 
the  multiplication.  We  saw  in  the  case  of  the  multiplication  routine  that 
this  subroutine  expected  to  find  the  multiplier  and  the  multiplicand  in 
given  memory  locations.  This  illustrates  one  method  of  passing  para- 
meters: tHitifigli  memory.  Two  other  techiUques  are  us#%  is^  Ihat  we 
liave  three  ways  of  passing  parameter:. 
1 — throiigh  registers 

Registers  can  be  used  to  pass  parameters.  This  is  an  advantageous 
solution,  provided  that  registers  are  available,  since  one  does  not  need 
t6  a  Hx&S  fheHlory  locatiom  the  subroutine  remains  memory-inde- 
pendent.  If  a  fixed  memory  location  is  used,  any  other  user  of  the  sub- 
routine must  be  very  careful  that  he  uses  the  same  convention  and  that 
the  memtHry  locirtibn  is  indeed  avaiUibie  (loolc  at  Exercise  3,19  above). 
This  is  why,  in  many  ea$es»  S^HtoA  of  memory  locations  is  reserved 
simply  to  pass  parameters  aiD^mg  various  subroutines. 

tMtltg  mmt^  has  th*  advantage  of  greater  flexibility  {more  data), 
but  results  in  poorer  performance  and  also  in  tying  the  subroutine  to  a 
given  memory  area. 

Depositing  pammetcrs  in  the  stack  has  the  same  advantage  as  using 
registers:  it  is  memory-independent.  The  subroutine  simply  knows  that 
it  is  supposed  to  receive,  say,  two  parameters  which  are  stored  on  top  of 
thi  iiti^,  Nitrnfly,  llteli^MMltlii^f  It  clutters  the  stack  with  data 
and,  therefore,  redu#!^  life  number  of  possible  levels  of  subroutine 
calls.  It  also  significanif  Mmplicates  the  use  of  the  stack,  and  may  re* 
quire  multiple  stacks. 

The  choice  is  up  to  the  programmer.  In  general,  one  wishes  to  remain 
independent  from  actual  memory  locations  as  long  as  possible. 


If  r^istefs  are  fiof  a^^A^le,  a  possible  solution  is  the  stack.  How- 
ever, if  a  large  quantity  infonnation  should  be  passed  to  a  sub- 
routine, this  information  ng^ltave  to  reside  directly  in  the  memory.  An 
elegant  way  aribVitd  VM  prolniem  of  passing  a  block  of  data  is  i^ply  to 
transmit  a  pointer  to  the  information.  A  poiruer  is  the  address  of  the 
beginning  of  the  block.  A  pointer  can  be  transmitted  in  a  register,  or  in 
t1ie$ni#  (t«i«NSgnetelsi@ttion$  ^  be  m&imsim$M  16<lift  inMt^i  or 
iQ  a  given  ntemoty  Iocatibn(s}. 
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Finally,  it  neilher  of  ihe  iwo  solutions  is  applicable,  ihen  an  agree- 

ffiiM  m0  W  #tlt  tM  ^Mmi&m-'&M'tM^^'^l  te:  m  mam 
i^eii  wemory  location  (the  **arf'-te»**Ji< 


Hxereise        Which  of  the  thr^  methods  i^om  is  b&t  fm'  recursion f 

Tfum  ttt  stfiifiig  advantage  to  structuring  pe«f£i0ii5idf  a  pi^^grtifi  into 
identifiable  subroutines:  they  can  be  debugged  independently  and 
have  a  mnemonic  name.  Provided  that  ihey  will  be  used  in  otha  iweas 
of  the  0r^|tiaR,  tifey  be«Miie  ^i»«^lei  and  &m  esn  ikm  baflid  » 
library  of  useful  subroutines.  However,  there  is  no  general  panacea  til 
computer  programmmg.  Using  subroutines  syslemalically  for  Jiil!^ 
gi^tip  of  instructions  that  can  be  grbVqgiQ  )^  function  may  also  in 
poor  efficiency.  The  alert  pro^ammcr  will  have  to  weigh  the  advan- 
tages against  the  disadvantages. 

SUMMAJEty 

This  chapter  has  presented  the  way  information  is  manipulated  inside 
the  Z80  by  instructions.  Increasingly  complex  algorithms  have  been  in- 
rjSBfioee^  a»d  translated  into  programs.  TTie  maift  Ifpjes  of  instructions 

have  been  used  and  explained. 

Imporlani  structures  such  as  loops,  stacks  and  subroutines,  have 
been  defined. 

You  should  now  have  acquired  a  basic  understanding  of  program- 
ming, and  of  the  major  techniques  used  in  standard  applications.  Let 
tiS  stiii^  the  iijsiructtotttJt^ 
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Fig.  3.39:  Multiplication:  A  Complete  Trace 
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Fig.  3.39:  Multiplication:  A  Complete  Trace  (continued) 


152 


BASIC  PROGRAMMING  TECHNIQUES 
ANSWERS  TO  EXERCISE  3.18  (MULTIPLICATION): 
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Fig.  3.40:  The  Maltiplication  Program  (Hex) 
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4 

THE  Z80  INSTRUCTION  SET 


INTRODUCTION 

This  chapter  will  first  analyze  the  various  classes  of  instructions 
which  should  be  available  In  a  general-purpose  computer.  It  will  then 
analyze  one  by  one  all  of  the  instructions  available  for  the  Z80,  and  ex- 
plain tn  detail  their  purpose  and  the  manner  in  which  they  affect  flags 
or  can  be  used  in  conjunction  with  various  addressing  modes.  A  de- 
tailed discussion  of  addressing  techniques  wit!  be  presented  in  Chapter 
5. 

CLASSES  OF  INSTRUCTIONS 

Instructions  may  be  classified  in  many  ways,  and  there  is  no  stan- 
dard. We  will  here  distinguish  five  mam  categories  of  instructions: 

1 —  data  transfers 

2 —  data  processing 

3 —  test  and  branch 

4 —  input/output 

5—  control 

Let  us  now  examine  each  of  these  classes  of  instructions  in  turn. 
Data  Transfers 

Data  transfer  instructions  will  transfer  data  between  registers,  or  be- 
tween a  register  and  memory,  or  between  a  register  and  an  input/output 
device.  Specialized  transfer  instructions  may  exist  for  registers  which 
piay  a  specific  role.  For  example,  push  and  pop  operations 
are  provided  for  efficient  stack  operation.  They  will  move  a  word  of 
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data  between  the  top  of  the  stack  and  the  accumulator  in  a  single  in- 
struction, while  automatically  updating  the  stack-pointer  register. 

Data  Processing 

Data  processing  instructions  fall  into  five  general  categories: 

1 —  arithmetic  operations  (such  as  plus/minus) 

2 —  bit  manipulation  (set  and  reset) 

3 —  increment  and  decrement 

4 —  logical  operations  (such  as  AND,  OR,  exclusive  OR) 

5 —  skew  and  shift  operations  (such  as  shift,  rotate) 

It  should  be  noted  that,  for  efficient  data  processing,  it  is  desirable  to 
have  powerful  arithmetic  instructions,  such  as  multiply  and  divide. 
Unfortunately,  they  are  not  available  on  most  microprocessors,  h  is 
also  desirable  to  have  powerful  shift  and  skew  instructions,  such  as 
shift  n  bits,  or  a  nibble  exchange,  where  the  right  half  and  the  left  half 
of  the  byte  are  exchanged.  These  are  also  usually  unavailable  on  most 
microprocessors. 

Before  examining  the  actual  Z80  instructions,  let  us  recall  the  dif- 
ference between  a  shift  and  a  rotation.  The  shift  will  move  the  contents 
of  a  register  or  a  memory  location  by  one  bit  location  to  the  left  or  to 
the  right.  The  bit  falling  out  of  the  register  will  go  into  the  carry  bit. 
The  bit  coming  in  on  the  other  side  will  be  a  "0"  except  m  the  case  of  an 
"arithmetic  shift  right,"  where  the  MSB  will  be  duplicated. 

!n  the  case  of  a  rotation,  the  bit  coming  out  still  goes  in  the  carry. 
However,  the  bit  coming  in  is  the  previous  value  which  was  in  the  carry 
bit.  This  corresponds  to  a  9-bit  rotation.  It  is  often  desirable  to  have  a 
true  8-bit  rotation  where  the  bit  coming  in  on  one  side  is  the  one  falling 
from  the  other  side.  This  is  not  provided  on  most  microprocessors 
but  is  available  on  the  Z80  (see  Figure  4. 1). 

Finally,  when  shifting  a  word  to  the  right,  it  is  convenient  to  have  one 
more  type  of  shift,  called  a  sign  extension  or  an  "arithmetic  shift 
right."  When  doing  operations  on  two's  complement  numbers,  parti- 
cularly when  implementing  floating-point  routines,  it  is  often  necessary 
to  shift  a  negative  number  to  the  right.  When  shifting  a  two's  comple- 
ment number  to  the  right,  the  bit  which  must  come  in  on  the  left  side 
should  be  a  "1"  (the  sign  should  get  repeated  as  many  limes  as  needed 
by  the  successive  shifts).  This  is  the  arithmetic  shift  right. 
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^  r 
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Fig.  4.1:  Shift  and  Rotate 


Test  and  Jump 

The  test  instructions  will  test  bits  in  the  specified  register  for  "0"  or 
"1",  or  combinations.  At  a  minimum,  it  must  be  possible  to  test  the 
flags  register,  U  is,  therefore,  desirable  to  have  as  many  flags  as  pos- 
sible in  this  register.  In  addition,  it  is  convenient  to  be  able  to  test  for 
combinations  of  such  bits  with  a  smgle  instruction.  Finally,  it  is 
desirable  to  be  able  to  test  any  bit  position  in  any  register,  and  to  test 
the  value  of  a  register  compared  to  the  value  of  any  other  register 
(greater  than,  less  than,  equal).  Microprocessor  test  instructions  are 
usually  limited  to  testmg  single  bits  of  the  flags  register.  The  Z80,  how- 
ever, offers  better  facilities  than  most. 

The  jump  instructions  that  may  be  available  generally  fall  into 
three  categories: 

1—  the  jump,  which  specifies  a  full  16-bii  address 

2—  the  relative  jump,  which  often  is  restricted  to  an  8-bit  displace- 
ment field 

3 —  the  call,  which  is  used  with  subroutines 
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It  IS  convenient  to  have  two-  or  even  three-way  jumps,  depending,  for 
example,  on  whether  the  result  of  a  comparison  is  "greater  than,"  "less 
than,"  or  "equal."  It  is  also  convenient  to  have  skip  operations,  which 
will  jump  forward  or  backwards  by  a  few  instructions.  However,  a 
"skip"  IS  equivalent  to  a  "jump."  Finally,  in  most  loops,  there  is 
usually  a  decrement  or  increment  operation  at  the  end,  followed  by  a 
test-and-branch.  The  availability  of  a  single-instruction  increment/ 
decrement  plus  test-and-branch  is,  therefore,  a  significant  advan- 
tage for  efficient  loop  implementation.  This  is  not  available  in  most 
microprocessors.  Only  simple  branches,  combined  with  simple  tests,are 
available.  This,  naturally,  complicates  programming  and  reduces  effi- 
ciency. In  the  case  of  the  Z80,  a  "decrement  and  jump"  instruction  is 
available.  However,  it  only  tests  a  specific  register  (B)  for  zero. 

Input/Output 

Input/output  instructions  are  specialized  instructions  for  the  hand- 
ling of  input/output  devices.  In  practice,  a  majority  of  the  8-bit  micro- 
processors use  memory-mapped  I/O:  input/output  devices  are  con- 
nected to  the  address  bus  just  like  memory  chips,  and  addressed  as 
such.  They  appear  to  the  programmer  as  memory  locations.  All 
memory-type  operations  normally  require  3  bytes  and  are,  therefore, 
slow.  For  efficient  input/output  handling  m  such  an  environment,  it  is 
desirable  to  have  a  short  addressing  mechanism  available  so  that  i/O 
devices  whose  handling  speed  is  crucial  may  reside  in  page  0.  However, 
if  page  0  addressing  is  available,  it  is  usually  used  for  RAM  memory, 
which  prevents  its  effective  use  for  input/output  devices.  The 
Z80,  like  the  8080,  is  equipped  with  specialized  I/O  instructions.  As  a 
result,  in  the  case  of  the  Z80,  the  designer  may  use  either  method;  in- 
put/output devices  may  be  addressed  as  memory  devices,  or  else  as  in- 
put/output devices,  using  the  I/O  instructions. 

They  will  be  described  later  in  this  chapter. 

Control  Instructions 

Control  instructions  supply  synchronization  signals  and  may  suspend 
or  interrupt  a  program.  They  can  also  function  as  a  break  or  a  simu- 
lated interrupt.  (Interrupts  will  be  described  in  Chapter  6  on  In- 
put/Output Techniques.) 
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THE  Z80  INSTRUCTION  SET 
Introduction 

The  Z80  microprocessor  was  designed  to  be  a  replacement  for  the 
8080,  and  to  offer  additional  capabilities.  As  a  result  of  this  design 
philosophy,  the  Z80  offers  all  the  instructions  of  the  8080,  plus  addi- 
tional instructions.  !n  view  of  the  limited  number  of  bits  available  in  an 
8'bit  opcode,  one  may  wonder  how  the  designers  of  the  Z80  succeeded 
m  implementing  many  additional  ones.  They  did  so  by  using  a  few 
unused  8080  opcodes  and  by  adding  an  additional  byte  to  the  opcode 
for  indexed  operations.  This  is  why  some  of  the  Z80  instructions  oc- 
cupy up  to  five  bytes  in  the  memory. 

It  IS  important  to  remember  that  any  program  can  be  written  in  many 
different  ways.  A  thorough  knowledge  and  understanding  of  the  in- 
struction set  IS  indispensable  for  achieving  efficient  programming. 
However,  when  learning  how  to  program,  it  is  not  essential  to  write  op- 
timized programs.  During  a  first  reading  of  this  chapter,  it  is  therefore 
unimportant  to  remember  all  the  various  instructions.  It  is  important  to 
remember  the  categories  of  instructions  and  to  study  typical  examples. 
Then,  when  writing  programs,  the  reader  should  consult  the  Z80 
mstruction-set  description,  and  select  the  instructions  best  suited  to  his 
needs.  The  various  instructions  of  the  Z80  will  therefore  be  reviewed  in 
this  section  with  the  intent  of  simplifying  them  and  grouping  ihem  in 
logical  categories.  The  reader  interested  m  exploring  the  capabilities  of 
the  various  instructions  is  referred  to  the  individual  descriptions  of  the 
instructions. 

We  will  now  examine  the  capabilities  provided  by  the  Z80  in  terms  of 
the  five  classes  of  instructions  which  have  been  defined  at  the  beginning 
of  this  chapter. 

Data  Transfer  Instructions 

Data  transfer  instructions  on  the  Z80  may  be  classified  tn  four 
categories:  8-bit  transfers,  16-bii  transfers,  stack  operations,  and 
block  transfers.  Let  us  examine  them. 

Eight-Bit  Data  Transfers 

All  eight-bit  data  transfers  are  accomplished  by  load  instructions. 
The  format  is: 

LP  destination,  source 
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For  example,  the  accumulator  A  may  be  loaded  from  register  B  by 
using  the  instructions: 

LD  A.B 

Direct  transfers  may  be  accomphshed  between  any  two  of  the 
working  registers  (ABCDEHL). 

In  order  to  load  any  of  the  working  registers,  except  for  the  accu- 
mulator, from  a  memory  location,  the  address  of  this  memory  loca- 
tion must  first  be  loaded  into  the  H-L  register  pair. 

For  example,  in  order  to  load  register  C  from  memory  location  1234, 
register  H  and  L  will  first  have  to  be  loaded  with  the  value  "1234",  (A 
load  instruction  operating  on  16  bits  will  be  used.  This  is  described  in 
the  following  section.) 

Then,  the  instruction  LD  C,  (HL)  will  be  used  and  will  accompHsh 
the  desired  result. 

The  accumulator  is  an  exception.  It  can  be  loaded  directly  from  any 
specified  memory  location.  This  is  called  the  extended  addressing 
mode.  For  example,  in  order  to  load  the  accumulator  with  the  contents 
of  memory  location  1234,  the  following  instruction  will  be  used: 

LD  A.  (1234H)  (Note  the  use  of  "( )"  to  denote  "contents  of.") 

The  instruction  will  be  stored  in  the  memory  as  follows; 

address    PC       :3A  (opcode) 

PC  +  1:34        (low  order  half  of  the  address) 
PC  +  2:12        (high  order  half  of  the  address) 

Note  that  the  address  is  stored  In  "reverse  order"  in  the  instruction 
itself: 


3A 


low  addr     high  addr 


All  the  working  registers  may  also  be  loaded  with  any  specified  eight-bit 
value,  or  "Hteral,"  contained  in  the  second  byte  of  the  instruction  (this 
is  called  immediate  addressing).  An  example  is: 

LD  E,  12H 

which  loads  register  E  with  the  value  12  hexadecimal. 
In  the  memory,  the  instruction  appears  as: 

PC:  IE  (opcode) 
PC  4-  1:  12       (literal  operand) 
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As  a  result  of  this  instruction,  the  immediate  operand,  or  literal  value 
will  be  contained  in  register  E. 

The  indexed  addressing  mode  is  also  available  for  loading  register 
contents,  and  will  be  fully  described  in  the  next  chapter  on  addressing 
techniques.  Other  miscellaneous  possibilities  exist  for  loading  specific 
registers,  and  a  table  listing  all  the  possibilities  is  shown  in  Figure  4.2 
( tables  supplied  by  Zilog,  Inc.),  The  grey  areas  show  instructions 
common  with  the  8080A. 
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Fig.  4,2:  Eight-Bit  Load  Group— 'LD' 

16-Bit  Data  Transfers 

Basically,  any  of  the  16-bit  register  pairs,  BC,  DE,  HL,  SP,  IX,  lY, 
may  be  loaded  with  a  literal  16-bit  operand,  or  from  a  specified 
memory  address  (extended  addressing),  or  from  the  top  of  the  stack, 
i.e.,  from  the  address  contained  in  SP,  Conversely,  the  contents  of  these 
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register  pairs  may  be  stored  in  the  same  manner  at  a  specified  memory 
address  or  on  top  of  the  stack.  Additionally,  the  SP  register  may  be 
loaded  from  HL,  IX,  and  lY.  This  facilitates  creating  multiple  stacks. 
The  register  pair  AF  may  also  be  pushed  on  top  of  the  stack. 

The  table  listing  all  the  possibilities  is  shown  in  Figure  4.3.  The  stack 
push  and  pop  operations  are  included  as  parts  of  the  16-bit  data 
transfers.  All  stack  operations  transfer  the  contents  of  a  register  pair  to 
or  from  the  stack.  Note  that  there  are  no  single  push  and  pop  instruc- 
tions for  saving  individual  eight-bit  registers. 
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Fig.  4.3:  16-Bit  Load  Group— 'LD',  'PUSH'  and  'POP' 

A  double-byte  push  or  pop  is  always  executed  on  a  register  pair:  AF, 
BC,  DE,  HL,  IX,  lY  (see  the  bottom  row  and  right-most  column  in 
Figure:  4,3). 

When  operating  on  AF,  BC,  DE.  HL,  a  single-byte  is  required  for  the 
instruction,  resulting  in  good  efficiency.  For  example,  assume  that  the* 
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stack  pointer  SP  contains  the  value  "0100".  The  following  instruc- 
tion iS  executed: 

PUSH  AF 

When  pushing  the  contents  of  the  register  pair  on  the  stack,  the  stack 
pointer  SP  is  first  decremented,  then  the  contents  of  register  A  are  de- 
posited on  top  of  the  stack.  Then  the  SP  is  decremented  again,  and  the 
contents  of  F  are  deposited  on  the  stack.  At  the  end  of  the  stack  trans- 
fer, SP  points  to  the  top  element  of  the  stack,  which  in  our  example 
IS  the  value  of  F. 

It  is  important  to  remember  that,  m  the  case  of  the  Z80,  the  SP 
points  to  the  top  of  the  stack  and  the  SP  is  decremented  whenever  a 
register  pair  is  pushed.  Other  conventions  are  often  used  in  other  pro- 
cessors, and  this  may  be  a  source  of  confusion. 
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Exchange  Instructions 

Additionally,  a  specialized  mnemonic  EX  has  been  reserved  for  ex- 
change operations.  EX  is  not  a  simple  data  transfer,  but  a  dual  data 
transfer.  It  actually  changes  the  contents  of  two  specified  locations.  EX 


162 


THE  Z80  INSTRUCTION  SET 


may  be  used  to  exchange  the  top  of  the  stack  with  HL,  IX,  lY  and  also 
to  swap  the  contents  of  DE  and  HL  and  AF  and  AF'  (remember  that 
AF'  stands  for  the  other  AF  register  pair  available  in  the  Z80). 

Finally,  a  special  EXX  instruction  is  available  to  exchange  the  con- 
tents of  BC,  DE,  HL  with  the  contents  of  the  corresponding  registers  m 
the  second  register  bank  of  the  Z80. 

The  possible  exchanges  are  summarized  in  Figure  4.4. 
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Fig.  4.5:  Block  Transfer  Group 


Block  Transfer  Instructions 

Block  transfer  instructions  are  instructions  which  will  result  in  the 
transfer  of  a  block  of  data  rather  than  a  single  or  double  byte.  Block 
transfer  instructions  are  more  complex  for  the  manufacturer  to  imple- 
ment than  most  instructions  and  are  usually  not  provided  on  micropro- 
cessors. They  are  convenient  for  programming,  and  may  improve  the 


163 


PROGRAMMING  THE  Z80 


performance  of  a  program,  especially  during  input/output  operation. 
Their  use  and  advantages  will  be  demonstrated  throughout  this  book. 
Some  automatic  block  transfer  instructions  are  available  in  the  case  of 
the  Z80.  They  use  specific  conventions. 

All  block  transfer  mstructions  require  the  use  of  three  pairs  of 
registers:  BC,  DE,  HL: 

BC  is  used  as  a  !6-bit  counter.  This  means  that  up  to  2"  =  64K  bytes 
may  be  moved  automatically.  HL  is  used  as  the  source  pointer.  It  may 
point  anywhere  m  the  memory,  DE  ts  used  as  the  destmation  pointer 
and  may  point  anywhere  in  the  memory. 

Four  block  transfer  instructions  are  provided: 

LDD,  LDDR,  LDI,  LDIR 

All  of  them  decrement  the  counter  register  BC  with  each  transfer.  Two 
of  them  decrement  the  pointer  registers  DE  and  HL,  LDD  and  LDDR, 
while  the  two  others  increment  DE  and  HL,  LDI  and  LDIR.  For  each 
of  these  two  groups  of  instructions,  the  letter  R  at  the  end  of  the 
mnemonic  indicates  an  automatic  repeat.  Let  us  examine  these  instruc- 
tions. 

LDI  stands  for  "load  and  increment."  It  transfers  one  byte  from  the 
memory  location  pointed  to  by  H  and  L  to  the  destination  in  the 
memory  pointed  to  by  D  and  E.  It  also  decrements  BC,  It  will  automati- 
cally increment  H  and  L  and  D  and  E  so  that  all  register  pairs  are  pro- 
perly conditioned  to  perform  the  next  byte  transfer  whenever  required. 

LDIR  stands  for  "load  increment  and  repeat,"  i,e,,  execute  LDI 
repeatedly  until  the  counter  registers  BC  reach  the  value  "0",  It  is  used 
to  move  a  continuous  block  of  data  automatically  from  one  memory 
area  to  another. 

LDD  and  LDDR  operate  in  the  same  way  except  that  the  address 
pointer  IS  decremented  rather  than  incremented.  The  transfer  therefore 
starts  at  the  highest  address  in  the  block  instead  of  the  lowest.  The  ef- 
fect of  the  four  instructions  is  summarized  in  Figure  4;5. 

Similar  automated  instructions  are  available  for  CP  (compare)  and 
are  summarized  in  Figure  4,6. 

Data  Processing  Instructions 

Arithmetic 

Two  mam  arithmetic  operations  are  provided:  addition  and  subtrac- 
tion. They  have  been  used  extensively  in  the  previous  chapter.  There  are 
two  types  of  addition,  with  and  without  carry,  ADC  and  ADD  respec- 
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tively.  Similarly,  two  types  of  subtraction  are  provided  witli  and 
without  carry.  They  are  SBC  and  SUB. 

Additionally,  three  special  instructions  are  provided:  DAA,  CPL, 
and  NEC  The  Dec imal^d just  Accumulator  instruction  DAA  has  been 
used  to  implement  BCD  operations.  It  is  normally  used  for  each  BCD 
add  or  subtract.  Two  complementation  instructions  also  are  available. 
CPL  will  compute  the  one's  complement  of  the  accumulator,  and  NEC 
will  negate  the  accumulator  into  its  complement  format(two's  comple- 
ment). 

AH  the  previous  instructions  operate  on  eight-bit  data.  16-bit  opera- 
tions are  more  restricted.  ADD,  ADC,  and  SBC  are  available  on 
specific  registers,  as  described  in  Figure  4.8. 

Finally,  increment  and  decrement  instructions  are  available  which 
operate  on  all  the  registers,  both  in  an  eight-bit  and  a  16-bit  format. 
They  are  listed  in  Figure  4.7  (eight-bit  operations)  and  4.8  (16-bit  opera- 
tions). 
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Fig,  4.7:  Eight-Bit  Arithmetic  and  Logic 


Note  that,  m  general,  all  arithmetic  operations  modify  some  of  the 
flags.  Their  effect  is  fully  described  in  the  instruction  descriptions  later 
in  this  chapter.  However,  it  is  important  to  note  that  the  INC  and  DEC 
instructions  which  operate  on  register  pairs  do  not  modify  any  of  the  flags. 
This  detail  is  important  to  keep  in  mind.  This  means  that  if  you  incre- 
ment or  decrement  one  of  the  register  pairs  to  the  value  "0",  the  Z-bit 
m  the  flags  register  F  will  not  be  set.  The  value  of  the  register  must  be 
explicitly  tested  for  the  value  "0"  in  the  program. 

Also,  it  is  important  to  remember  that  the  instructions  ADC  and  SBC 
always  affect  all  the  flags.  This  does  not  mean  that  ail  the  flags  will 
necessarily  be  different  after  their  execution.  However,  they  might. 
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Logical 

Three  logical  operations  are  provided:  AND,  OR  (inclusive)  and 
XOR  (exclusive),  plus  a  comparison  instruction  CP.  They  all  operate 
exclusively  on  eight-bit  data.  Let  us  examine  them  in  turn.  (A  table  list- 
ing all  the  possibilities  and  operation  codes  for  these  instructions  is  part 
of  Figure  4.7.) 

AND 

Each  logical  operation  is  characterized  by  a  truth  table,  which  ex- 
presses the  logical  value  of  the  result  in  function  of  the  inputs.  The 
truth  table  for  AND  appears  below: 
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0  AND  0  =0 
OAND 1  =  0 
1 ANDO  =  0 

1  AND  J  =  1 


or 


AND 

0 

i 

0 

0 

0 

i 

0 

1 

The  AND  operation  is  characterized  by  the  fact  that  the  output  is 
"1"  only  if  both  inputs  are  "I",  In  other  words,  if  one  of  the  inputs  is 
"0",  it  is  guaranteed  that  the  result  is  "0".  This  feature  is  used  to  zero 
a  bit  position  in  a  word.  This  is  called  "masking," 

One  of  the  important  uses  of  the  AND  instruction  is  to  clear  or 
"mask  out"  one  or  more  specified  bit  positions  in  a  word.  Assume  for 
example  that  we  want  to  zero  the  right-most  four-bit  positions  in  a 
word.  This  will  be  performed  by  the  following  program: 

LD        A,  WORD  WORD  CONTAINS '10101010' 

AND         UllOOOOB  'HI  10000' IS  MASK 


Let  us  assume  that  WORD  is  equal  to  'lOlOlOIO*.  The  result  of  this 
program  is  to  leave  the  value  'lOlOOOOO'  in  the  accumulator.  "B"  is 
used  to  indicate  a  binary  value.  > 

Exercise  4,1:  Write  a  three-line  program  which  will  zero  bits  1  and  6  of 
WORD. 

Exercise 4.2:  What  happens  with  a  MASK  =  'nUUlVI 
OR 

This  instruction  is  the  inclusive  OR  operation.  It  is  characterized  by 
the  following  truth  table: 


OORO  =0 

0  OR  1  =  1 

1  OR  0  =  1 
!  OR  i  =  1 


or 


OR 

0 

1 

0 

0 

1 

1 

1 

1 

The  logical  OR  is  characterized  by  the  fact  that  if  one  of  the  operands 
is  "1",  then  the  result  is  always  The  obvious  use  of  OR  is  to  set 
any  bit  in  a  word  to  "1". 

Let  us  set  the  right-most  four  bits  of  WORD  to  I's.  The  program  is: 

LD    A,  WORD 
OR  A.OOOOIIIIB 
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Let  us  assume  that  WORD  did  contain  '10101010'.  The  final  value  of 
the  accumulator  will  be  '10101111', 

Exercise  4.3:  What  would  happen  if  we  were  to  use  the  instruction 
ORIQIOUHB? 

Exercise  4.4:  What  is  the  effect  of  ORing  with  "PF"  hexadecimal? 
XOR 

XOR  stands  for  "exclusive  OR."  The  exclusive  OR  differs  from  the 
inclusive  OR  that  we  have  just  described  in  one  respect:  the  result  is 
"1"  only  if  one,  and  only  one,  of  the  operands  is  equal  to  "1",  If  both 
operands  are  equal  to  "1",  the  normal  OR  would  give  a  "1"  result. 
The  exclusive  OR  gives  a  "0"  result.  The  truth  table  is: 


0  XOR  0  =0 

0  XOR 1  =  i 

1  XOR  0  =  1 
1  XOR  1  =  0 


XOR 

0 

i 

0 

0 

1 

I 

1 

0 

The  exclusive  OR  is  used  for  comparisons.  If  any  bit  is  different,  the 
exclusive  OR  of  two  words  will  be  non-zero.  In  addition,  in  the  case  of 
the  Z80,  the  exclusive  OR  may  be  used  to  complement  a  word,  since 
there  is  no  complement  instruction  on  anything  but  the  accumulator. 
This  is  done  by  performing  the  XOR  of  a  word  with  all  ones.  The  pro- 
gram appears  below: 

LD  r.  WORD 
XOR,  UIlllll  B 
LD  r.  A 

where  "r"  designates  the  register. 

Let  us  assume  that  WORD  contained  "10101010".  The  final  value  of 
the  register  will  be  "01010101",  You  can  verify  that  this  is  the  comple- 
ment of  the  original  value. 

XOR  can  be  used  to  advantage  as  a  "bit  toggle." 

Exercise  4.5:  What  is  the  effect  of  XOR  using  a  register  with  "00"  hex- 
adecimal? 

Skew  Operations  (Shift  and  Rotate) 

Let  us  first  differentiate  between  the  shift  and  the  rotate  operations, 
which  are  illustrated  in  Figure  4.9.  In  a  shift  operation,  the  contents  of 
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the  register  are  shifted  to  the  left  or  to  the  right  by  one  bit  position.  The 
bit  which  falls  out  of  the  register  goes  into  the  carry  bit  C,  and  the  bit 
which  comes  in  is  zero.  This  was  explained  in  the  previous  section. 


r^      r\  r^  r\  r-\  r-\ 


CARRY 


■\  r 

\  r 

-\  r 

^  r 

Fig.  4.9:  Shift  and  Rotate 


One  exception  exists;  it  is  the  shifl-right-arithmetic.  When  perform- 
ing operations  on  negative  numbers  in  the  two's  complement  format, 
the  left-most  bit  is  the  sign  bit.  In  the  case  of  negative  numbers  it  is 
"1",  When  dividing  a  negative  number  by  "2"  by  shifting  it  to  the 
right,  it  should  remain  negative,  i.e.,  the  left-most  bit  should  remain  a 
"1",  This  IS  performed  automatically  by  the  SRA  instruction  or  Shift 
Right  Arithmetic.  In  this  arithmetic  shift  right,  the  bit  which  comes  in 
on  the  left  is  identical  to  the  sign  bit.  It  is  "0"  if  the  left-most  bit  was  a 
"0".  and  "1"  if  the  left-most  bit  was  a  "1".  This  is  illustrated  on  the 
right  of  Figure  4, 10,  which  shows  all  the  possible  shift  and  rotate  opera- 
tions. 

Rotations 

A  rotation  differs  from  a  shift  by  the  fact  that  the  bit  coming  into  the 
register  is  the  one  which  will  fall  from  either  the  other  end  of  the 
register  or  the  carry  bit.  Two  types  of  rotations  are  supplied  in  the  case 
of  the  Z80:  an  eight-bit  rotation  and  a  mne-bit  rotation. 

The  nme-bit  rotation  is  illustrated  in  Figure  4.1 1.  For  example,  in  the 
case  of  a  right  rotation,  the  eight  bits  of  the  register  are  shifted  right  by 
one  bit  position.  The  bit  which  falls  off  the  right  part  of  the  register 
goes,  as  usual,  into  the  carry  bit.  At  this  time  the  bit  which  comes  m  on 
the  left  end  of  the  register  is  the  previous  value  of  the  carry  bit  (before  it 
is  overwritten  with  the  bit  falling  out.)  in  mathematics  this  is  called  a 
nine-bit  rotation  since  the  eight  bits  of  the  register  plus  the  ninth  bit  (the 
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carry  bit)  are  rotated  to  the  right  by  one  bit  position.  Conversely,  the 
left  rotation  accomplishes  the  same  result  in  the  opposite  direction. 


1 

1 

3 1. 


Fig.  4.10:  Rotates  and  Shifts 


7       REGISTER        0   C 


RIGHT 


1 

1  — ^ 

7        REGISTER  0 

C 

1 

■j  

n 


Fig.  4.11:  Nine-Bit  Rotation 


The  eight-bit  rotation  operates  in  a  similar  way.  Bit  0  !s  copied  into 
bit  seven,  or  else  bit  seven  is  copied  into  bit  0,  depending  on  the  direc- 
tion of  the  rotation.  In  addition,  the  bit  coming  out  of  the  register  is 
also  copied  in  the  carry  bit.  This  is  illustrated  by  Figure  4.12. 


RIGHT 


LEFT 


0 


!  I 


Fig.  4,12:  Eight-Bit  Rotation 
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Special  Digit  Instructions 

Two  special  digit-rotate  instructions  are  provided  to  facilitate  BCD 
arithmetic.  The  result  is  a  four-bit  rotation  between  two  digits  con- 
tained in  the  memory  location  pointed  to  by  the  HL  registers  and  one 
digit  in  the  lower  half  of  the  accumulator.  This  is  illustrated  by  Figure 
4.13. 


MEMORY 


MEMORY 


Fig.  4.13:  Digit  Rotate  Instructions  (Rotate  Decimal) 


Bit  Manipulation 

it  has  been  shown  above  how  the  logical  operations  may  be  used  to 
set  or  reset  bits  or  groups  of  bits  in  specific  registers.  However,  it  is  con- 
venient to  set  or  reset  any  bit  in  any  register  or  memory  location  with  a 
single  instruction.  This  facility  requires  a  considerable  number  of  op- 
codes and  is  therefore  usually  not  provided  on  most  microprocessors. 
However,  the  Z80  is  equipped  with  extensive  bit-manipulation 
facilities.  They  are  shown  in  Figure  4.14.  This  table  also  includes  the 
test  instructions  which  will  be  described  only  in  the  next  section. 

,Two  special  instructions  are  also  available  for  operating  on  the  carry 
flag.  They  are  CCF  (Complement  Carry  Flag)  and  SCF  (Set  Carry 
Flag).  They  are  shown  in  Figure  4.15. 

Test  and  Jump 

Since  testing  operations  rely  heavily  on  the  use  of  the  flags  register, 
we  will  here  describe  in  detail  the  role  of  each  of  the  flags.  The  contents 
of  the  flags  register  appear  in  Figure  4.16. 
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Fig.  4.14:  Bit  Manipulation  Group 
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□Ecmai  Adjust  Ace.  'DAA' 

27 

Complement  Acc.  'CPL' 

2F 

Negate  Acc,  'NEC 
(2's  complement} 

ED 
4iJ 

Complement  Carry  Flag.  'CCF' 

3F 

Sot  Carrv  Flag,  'SCF' 

37 

Fig.  4.15;  General-Purpose  AF  Operations 
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Fig.  4.16:  The  Flags  Register 


C  is  the  carry,  N  is  add  or  subtract,  P/V  is  parity  or  overflow,  H  is  half 
carry,  Z  is  zero,  S  is  sign.  Bits  3  and  5  of  tiie  flags  register  are  not  used 
("  ~  ").  The  two  flags  H  and  N  are  used  for  BCD  arithmetic  and  cannot 
be  tested.  The  other  four  flags  (C,  P/V,  2,  S)  can  be  tested  in  conjunc- 
tion with  conditional  jump  or  call  instructions. 
The  role  of  each  flag  will  now  be  described. 

Carry  (C) 

In  the  case  of  nearly  all  microprocessors,  and  of  the  Z80  in  par- 
ticular, the  carry  bit  assumes  a  dual  role.  First,  it  is  used  to  indicate 
whether  an  addition  or  subtraction  operation  has  resulted  in  a  carry  (or 
borrow).  Secondly,  it  is  used  as  a  ninth  bit  in  the  case  of  shift  and  rotate 
operations.  Using  a  single  bit  to  perform  both  roles  facilitates  some 
operations,  such  as  a  multiplication  operation.  This  should  be  clear 
from  the  explanation  of  the  multiplication  which  has  been  presented  in 
the  previous  chapter. 
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When  learning  to  use  the  carry  bit,  it  is  important  to  remember  that 
all  arithmetic  operations  will  either  set  it  or  reset  it,  depending  on  the 
result  of  the  instructions.  Similarly,  all  shift  and  rotation  operations  use 
the  carry  bit  and  will  either  set  it  or  reset  it,  depending  on  the  value  of 
the  bit  which  comes  out  of  the  register. 

In  the  case  of  logical  instructions  (AND,  OR,  XOR),  the  carry  bit 
will  always  be  reset.  They  may  be  used  to  zero  the  carry  explicitly. 

Instructions  which  affect  the  carry  bit  are:  ADD  A,s;  ADC  A,s; 
SUB  s;  SBC  A,s;  CP  s;  NEG;  AND  s;  OR  s;  XOR  s;  ADD  DD,ss;  ADC 
HL,ss:  SBC  HL.ss;  RLA;  RLCA;  RRA;  RRCA;  RL  m;  RLC  m;  RR  m; 
RRC  m;  SLA  m;  SRA  m;  SRL  m;  DDA;  SCF;  CCF;  NEG  s; 

Subtract  (N) 

This  flag  is  normally  not  used  by  the  programmer,  and  is  used  by  the 
Z80  itself  during  BCD  operations.  The  reader  will  remember  from  the 
previous  chapter  that,  following  a  BCD  add  or  subtract,  a  DAA 
(Decimal  Adjust  Accumulator)  instruction  is  executed  to  obtam  the 
valid  BCD  results.  However,  the  "adjustment"  operation  is  different 
after  an  addition  and  after  a  subtraction.  The  DAA  therefore  executes 
differently  depending  on  the  value  of  the  N  flag.  The  N  flag  is  set  to 
"0"  after  an  addition  and  is  set  to  a  "1"  after  a  subtraction. 

The  symbol  used  for  this  flag,  "N",  may  be  confusing  to  program- 
mers who  have  used  other  processors,  since  it  may  be  mistaken  for  the 
sign  bit.  It  is  an  internal  operation  sign  bit. 

N  is  set  to  "0"  by:  ADD  A,s;  ADC  A,s;ANDs;ORs:  XORs;  iNCs; 
ADD  DD,ss;  ADC  HL.ss;  RLA;  RLCA;  RRA;  RRCA;  RL  m;  RLC  m; 
RR  m;  RRC  m;  SLA  m;  SRA  m;  SRL  m;  RLD;  RRD;  SCF;  CCF;  IN  r. 
(C);  LDI;  LDD;  LDIR;  LDDR;  LD  A,  I;  LD  A,  R;  BIT  b.  s. 

N  is  set  to  "1"  by:  SUB  s;  SBC  A,s;  CP  s;  NEG;  DEC  m;  SBC  HL,  ss; 
CPL;  INI:  IND;  OUTl;  OUTD;  INIR;  INDR;  OTIR;  OTDR;  CPi; 
CPIR;  CPD;  CPDR. 

Parity/Overflow  fP/  V) 

The  parity/overflow  flag  performs  two  different  functions.  Specific 
instructions  will  set  or  reset  this  flag  depending  on  the  parity  of  the 
result;  parity  is  determined  by  counting  the  total  number  of  ones  in  the 
result.  If  this  number  is  odd,  the  parity  bit  will  be  set  to  "0"  (odd  pari- 
ty). If  it  is  even,  the  parity  bit  will  be  set  to  "1"  (even  parity).  Parity  is 
most  frequently  used  on  blocks  of  characters  (usually  in  the  ASCII  for- 
mat). The  parity  bit  is  an  additional  bit  which  is  added  to  the  seven-bit 
code  representing  the  character,  in  order  to  verify  the  integrity  of  data 
which  has  been  stored  in  a  memory  device.  For  example,  if  one  bit  in 
the  code  representing  the  character  has  been  changed  by  accident,  due 
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to  a  malfunction  in  the  memory  device  (such  as  a  disk  or  RAM 
memory),  or  during  transmission,  then  the  total  number  of  ones  in  the 
seven-bit  code  will  have  been  changed.  By  checking  the  parity  bit,  the 
discrepancy  will  be  detected,  and  an  error  will  be  flagged.  In  particular, 
the  flag  is  used  with  logical  and  rotate  instructions.  Also,  naturally, 
dunng  an  input  operation  from  an  I/O  device,  the  parity  flag  will  m- 
dicate  the  parity  of  the  data  being  read. 

For  the  reader  familiar  with  the  Intel  8080,  note  that  the  parity  flag  m 
the  8080  is  used  exclusively  as  such.  In  the  case  of  the  Z80,  it  is  used  for 
several  additional  functions.  This  flag  should  therefore  be  handled  with 
care  when  going  from  one  of  the  microprocessors  to  the  other. 

In  the  case  of  the  Z80,  the  second  essential  use  of  this  flag  is  as  an 
overflow  flag  (not  available  in  the  8080).  The  overflow  flag  has  been  de- 
scribed in  Chapter  1,  when  the  two's  complement  notation  was  intro- 
duced. It  detects  the  fact  that,  during  an  addition  or  subtraction,  the 
sign  of  the  result  is"accidentally"changed  due  to  the  overflow  of  the 
result  into  the  sign  bit.  (Recall  that,  using  an  eight-bit  representation, 
the  largest  positive  number  is  +  127,  and  the  smallest  negative  number 
IS  - 128  in  two's  complement.) 

Finally,  this  bit  is  also  used,  in  the  case  of  the  Z80,  for  two  unrelated 
functions. 

During  the  block  transfer  instructions  (LDD,  LDDR,  LDI,  LDIR), 
and  during  the  search  instructions  (CPD,  CPDR.  CPI,  CPIR),  this  flag 
is  used  to  detect  whether  the  counter  register  B  has  attained  the  value 
"0".  With  decrementing  instructions,  this  flag  is  reset  to  "0"  if  the 
byte  counter  register  pair  is  "0" .  When  incrementing,  it  is  reset  if  EC  - 
1  =  0  at  the  beginning  of  the  instruction,  i.e.,  if  EC  will  be  decremented 
to  "0"  by  the  instruction. 

Finally,  when  executing  the  two  special  instructions  LD  A,  I  and  LD 
A,R,  the  P/V  flag  reflects  the  value  of  the  interrupt  enable  flip-flop 
(IFF2).  This  feature  can  be  used  to  preserve  or  test  this  value. 

The  P  flag  is  affected  by:  AND  s;  OR  s;  XOR  s;  RL  m;  RLC  m;  RR  m; 
RRC  m;  SLA  m;  SRA  m;  SRL  m;  RLD;  RRD;  DAA;  INr,(C). 

The  V  nag  is  affected  by:  ADD  A,s;  ADC  A.s;  SUB  s;  SBC  A,s;  CP  s; 
NEC:  INCs;  DEC  m;  ADC  HL,ss;  SBC  HL.ss. 

It  is  also  used  by;  LDIR;  LDDR  (set  to  "0");  LDi;  LDD;  CPI; 
CPIR;  CPD;  CPDR. 

The  Half-Carry  Flag  (H) 

The  half-carry  flag  indicates  a  possible  carry  from  bit  3  into  bit  4  dur- 
ing an  arithmetic  operation.  In  other  words,  it  represents  the  carry  from 
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the  iow-order  nibble  (group  of  4  bits)  into  the  high  order  one.  Clearly,  it 
is  primarily  used  for  BCD  operations.  In  particular,  it  is  used  internally 
within  the  microprocessor  by  the  Decimal  Adjust  Accumulator  (DAA) 
instruction  in  order  to  adjust  the  result  to  its  correct  value. 

This  flag  will  be  set  during  an  addition  when  there  is  a  carry  from  bit 
3  to  bit  4  and  reset  when  there  is  no  carry.  Conversely,  during  a  subtract 
operation,  it  will  be  set  if  there  is  a  borrow  from  bit  4  to  bit  3,  and  reset 
if  there  is  no  borrow. 

The  flag  will  be  conditioned  by  addition,  subtraction,  increment, 
decrement,  comparisons,  and  logical  operations. 

Instructions  which  affect  the  H  bit  are:  ADD  A,r  ;  ADD  A,s;  SUB  s; 
SBC  A,s;  CP  s;  NEC;  AND  s;  OR  s;  XOR  s;  INC  s;  DEC  m;  RLA; 
RLCA;  RRA;  RRCA;  RL  m;  RLC  m;  RR  m;  RRC  m;  SLA  m;  SR  m; 
SRL  m;  RLD;  RRD;  DAA;  CPL,  SCF;  IN  r,(C) ;  LDI;  LLD;  LDiR; 
LDDR:  LD  A;  LD  A,r;  BIT  b.r. 

Note  that  the  H  bit  is  randomly  affected  by  the  i6-bit  add  and  sub- 
tract instructions,  and  by  block  input  and  output  instructions. 

Zero  (Z) 

The  Z  flag  is  used  to  indicate  whether  the  value  of  a  byte  which  has 
been  computed,  or  is  being  transferred,  is  zero.  It  is  also  used  with  com- 
parison instructions  to  indicate  a  match,  and  for  other  miscellaneous 
functions. 

In  the  case  of  an  operation  resulting  in  a  zero  result,  or  of  a  data 
transfer,  the  Z  bit  is  set  to  "1"  whenever  the  byte  is  zero.  Z  is  reset  to 
"0"  otherwise. 

In  the  case  of  comparison  instructions,  the  Z  bit  is  set  to  "I"  when- 
ever the  comparison  succeeds  and  to  "0"  otherwise. 

Additionally,  m  the  case  of  the  Z80,  it  is  used  for  three  more  functions; 
!t  is  used  with  the  BIT  instruction  to  indicate  the  value  of  a  bit  being 
tested.  It  is  set  to  "1"  if  the  specified  bit  is  "0"  and  reset  otherwise. 

With  the  special  "block  input-output  instructions"  (INI,  IND, 
OUTI,  OUTD),  the  Z  flag  is  set  if  D  -  I  =  0,  and  reset  otherwise;  it  is 
set  if  the  byte  counter  will  decrement  to  "0"  (INIR,  INDR,  OTIR, 
OTDR). 

Finally,  with  the  special  instructions  IN  r,{C)i  the  Z  flag  is  set  to  "1" 
to  indicate  that  the  input  byte  has  the  value  "0", 

In  summary,  the  following  instructions  condition  the  value  of  the  Z 
bit:  ADD  A,s;  ADC  A,s;SUB  s;  SBC  A,s;  CP  s;  NEC;  AND  s;  OR  s; 
XOR  s;  INC  s;  DEC  m;  ADC  HL,  ss;  SBC  HL.ss;  RL  m;  RLC  m; 
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RR  m;  RRC  m;  SLA  tn;  SRA  m;  SRL  m;  RLD;  RRD;  DAA;  IN  r,(C); 
INI;  IND;  OUTI:  OUTD;  INIR;  INDR;  OTIR;  OTDR;  CPI;  CPIR; 
CPD;  CPDR;  LD  A,  I;  LD  A,  R;  BIT  b.s;  NEC  s. 

Usual  instructions  which  do  not  affect  the  Z  bit  are:  ADD  DD.ss; 
RLA;  RLCA;  RRA;  RRCA;  CPL;  SCF;  CCF;  LDI;  LDD;  LDIR; 
LDDR:  INC  DO;  DEC  DD. 

Sign  (S) 

This  flag  reflects  the  value  of  the  most  significant  bit  of  a  result  or  of 
a  byte  being  transferred  (bit  seven).  In  two's  complement  notation,  the 
most  significant  bit  is  used  to  represent  the  sign.  "0"  indicates  a  posi- 
tive number  and  a  "1"  indicates  a  negative  number.  As  a  result,  bit 
seven  is  called  the  sign  bit. 

In  the  case  of  most  microprocessors,  the  sign  bit  plays  an  important 
role  when  communicating  with  input/output  devices.  Most  micropro- 
cessors are  not  equipped  with  a  BIT  instruction  for  testing  the  contents 
of  any  bits  in  a  register  or  the  memory.  As  a  result,  the  sign  bit  is  usual- 
ly the  most  convenient  bit  to  test.  When  examining  the  status  of  an  in- 
put/output device,  reading  the  status  register  will  automatically  condi- 
tion the  sign  bit,  which  will  be  set  to  the  value  of  bit  seven  of  the  status 
register.  It  can  then  be  tested  conveniently  by  the  program.  This  is  why 
the  status  register  of  most  input/output  chips  connected  to  micropro- 
cessor systems  have  their  most  important  indicator  (usually  ready/not 
ready)  in  bit  position  seven. 

A  special  BIT  instruction  is  provided  in  the  case  of  the  Z80. 
However,  in  order  to  test  a  memory  location  (which  may  be  the  address 
of  an  I/O  status  register),  the  address  must  first  be  loaded  into  registers 
IX,  lY  or  HL.  There  is  no  bit  instruction  provided  to  test  a  specified 
memory  address  directly  (i.e.,  no  direct  addressing  mode  for  this  in- 
struction). The  value  of  positioning  an  input/output  ready  flag  in  bit 
position  seven,  therefore,  remains  intact,  even  in  the  case  of  the  Z80. 

Finally,  the  sign  flag  is  used  by  the  special  instruction  IN,  (C)  to  in- 
dicate the  sign  of  the  data  being  read. 

Instructions  which  affect  the  sign  bit  are:  ADD  A,s;  SUB  s;  SBC  A,s; 
CP  s;  NEC;  AND  s;  OR  s;  XOR  s;  INC  s:  DEC  m;  ADC  HL,  ss:  SBC 
HL,  ss;  RL  m;  RLC  m;  RR  m;  RRC  m;  SLA  m;  SRA  m;  SRL  m;  RLD  ; 
RRD;  DAA;  IN  r.(C);  CPR;  CPIR;  CPD;  CPDR;  LD  A,I;LDA,r; 
NEC. 
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Summary  of  the  Flags 

The  flag  bits  are  used  to  automatically  detect  special  conditions  with- 
in the  ALU  of  the  microprocessor.  They  can  be  conveniently  tested  by 
specialized  instructions,  so  that  specific  action  can  be  taken  in  response 
to  the  condition  detected.  It  is  important  to  understand  the  role  of  the 
various  indicators  available,  since  most  decisions  taken  within  the  pro- 
gram will  be  taken  in  function  of  these  flag  bits.  All  jumps  executed 
within  a  program  will  jump  to  specified  locations  depending  on  the 
status  of  these  flags.  The  only  exception  involves  the  interrupt 
mechanism,  which  will  be  described  in  the  chapter  on  input/output  and 
may  cause  jumping  to  specific  locations  whenever  a  hardware  signal  is 
received  on  specialized  pins  of  the  Z80. 

At  this  point,  it  is  only  necessary  to  remember  the  main  function  of 
each  of  these  bits.  When  programming,  the  reader  can  refer  to  the  de- 
scription of  the  instruction  later  in  this  chapter  to  verify  the  effect  of 
every  instruction  of  the  various  flags.  Most  flags  can  be  ignored  most  of 
the  time,  and  the  reader  who  is  not  yet  familiar  with  them  should  not 
feel  intimidated  by  their  apparent  complexity.  Their  use  will  become 
clearer  as  we  examine  more  application  programs. 

A  summary  of  the  six  flags  and  the  way  they  are  set  or  reset  by  the 
various  instructions  is  shown  in  Figure  4.17. 

The  Jump  Instructions 

A  branch  instruction  is  an  instruction  which  causes  a  forced  bran- 
ching to  a  specified  program  address.  It  changes  the  normal  flow  of 
execution  of  the  program  from  a  sequential  mode  into  one  where  a  dif- 
ferent segment  of  the  program  is  suddenly  executed.  Jumps  may  be 
conditional  or  unconditional.  An  unconditional  jump  is  one  in  which 
the  branching  occurs  to  a  specific  address,  regardless  of  any  other  con- 
dition. 

A  conditional  jump  is  one  which  occurs  to  a  specific  address  only  if 
one  or  more  conditions  are  met.  This  is  the  type  of  jump  instruction 
used  to  make  decisions  based  upon  data  or  computed  results. 

In  order  to  explain  the  conditional  jump  instructions,  it  is  necessary 
to  understand  the  role  of  the  flags  register,  since  all  branching  decisions 
are  based  upon  these  flags.  This  was  the  purpose  of  the  preceding  sec- 
tion. We  can  now  examine  in  more  detail  the  jump  instructions  pro- 
vided by  the  Z80. 

Two  mam  types  of  jump  instructions  are  provided:  jump  instructions 
Within  the  main  program  (they  are  called  "jumps"),  and  the  special 
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type  of  branch  instructions  used  to  jump  to  a  subroutine  and  to  return 
from  it  {"cail"  and  "return").  As  a  result  of  any  jump  instruction,  the 
program  counter  PC  will  be  reloaded  with  a  new  address,  and  the  usual 
program  execution  will  resume  from  this  point  on.  The  full  power  of 
the  various  jump  instructions  can  be  understood  only  in  the  context  of 
the  various  addressing  modes  provided  by  the  microprocessor.  This 
part  of  the  discussion  will  be  deferred  until  the  next  chapter,  where  the 
addressing  modes  are  discussed.  We  will  only  consider  here  the  other 
aspects  of  these  instructions. 

Jumps  may  be  unconditionaJ  {branching  to  a  specified  memory  ad- 
dress) or  else  conditional,  in  the  case  of  a  conditional  jump,  one  of  four 
flag  bits  may  be  tested.  They  are  the  Z,  C,  P/V,  and  S  flags.  Each  of 
them  may  be  tested  for  the  value  "0"  or  "1". 

The  corresponding  abbreviations  are: 


z  = 

zero  (Z  =  I) 

NZ  = 

non  zero  (Z  =  0) 

\^  — 

carry  (C  =  1) 

NC  = 

no  carry  (C  =  0 ) 

PO  = 

odd  parity 

PE  = 

even  parity 

P  = 

positive  (S  =  0) 

M  = 

minus  (3  =  1) 

In  addition,  a  special  combination  instruction  is  available  in  the  Z80 
which  will  decrement  the  B  register  and  jump  to  a  specified  memory  ad- 
dress as  long  as  it  is  not  zero.  This  is  a  powerful  instruction  used  to  ter- 
minate a  loop,  and  it  has  already  been  used  several  times  in  the  previous 
chapter:  it  is  the  DJNZ  instruction. 

Similarly,  the  CALL  and  the  RET  (return)  instructions  may  be  condi- 
tional or  unconditional.  They  test  the  same  flags  as  the  branch  instruc- 
tion which  we  have  already  described. 

The  availability  of  conditional  branches  is  a  powerful  resource  in  a 
computer  and  is  generally  not  provided  on  other  eight-bit  micropro- 
cessors. It  improves  the  efficiency  of  programs  by  implementing  in  a 
single  instruction  what  requires  two  instructions  otherwise. 

Finally,  two  special  return  instructions  have  been  provided  in  the  case 
of  interrupt  routines.  They  are  RETi  and  RETN.  They  will  be  described 
in  the  section  of  Chapter  6  on  interrupts. 

The  addressing  modes  and  the  opcodes  for  the  various  branches 
available  are  shown  m  Figure  4.18. 
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Fig.  4.18:  Jump  Instructions 


A  detailed  discussion  of  the  various  addressing  modes  is  presented 
m  Chapter  5. 

By  examining  Figure  4.18,  it  becomes  apparent  that  many  ad- 
dressing modes  are  restricted.  For  example,  the  absolute  jump  JP  nn 
can  test  four  flags,  while  JR  can  only  test  two  flags. 

Note  an  important  observation;  JR  tends  to  be  used  whenever 
possible  as  it  is  shorter  than  JP  (one  less  byte)  and  facilitates  program 
relocation.  However,  JR  and  JP  are  not  interchangeable:  JR  cannot 
test  the  parity  or  the  sign  flags. 
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One  more  type  of  specialized  branch  is  available;  this  is  the  restart  or 
RST  instruction.  It  is  a  one-byte  instruction  which  allows  jumping  to 
any  one  of  eight  starting  addresses  at  the  low  end  of  the  memory.  Its 
starting  addresses  are,  in  decimal,  0,  8,  16,  24,  32,  40,  48  and  56.  It  is  a 
powerful  instruction  because  it  is  implemented  in  a  single  byte.  It  pro- 
vides a  fast  branch,  and  for  this  reason  is  used  essentially  to  respond  to 
interrupts.  However,  it  is  also  available  to  the  programmer  for  other 
uses.  A  summary  of  the  opcodes  for  this  instruction  is  shown  in  Figure 
4.19. 


OP 

CODE 

n't 

C7 

'RST  0' 

0008^ 

CF 

'RST  8' 

c 

A 

0010„ 

D7 

■RST  16' 

L 

L 

A 

0018^, 

DF 

'RST  24' 

D 

D 

R 
£ 

0020„ 

E7 

*RST  32' 

S 

S 

'RST  40' 

'RST  48' 

0038^ 

S'iii 

'RST  56' 

H  indicate*  a  hexidecitnal  numbor. 
Fig.  4.19:  Restart  Group 


Input/Output  Instructions 

Input/output  techniques  will  be  described  in  detail  m  Chapter  6. 
Simply,  input/output  devices  may  be  addressed  in  two  ways:  as 
memory  locations,  using  any  one  of  the  instructions  that  have  already 
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been  described,  or  using  specific  input/output  instructions.  Usual 
memory  addressing  instructions  use  three  bytes:  one  byte  for  the  op- 
code and  two  bytes  for  the  address.  As  a  result,  they  are  slow  to  ex- 
ecute, since  they  require  three  memory  accesses.  The  main  purpose  of 
specialized  input/output  instructions  is  to  provide  shorter  and, 
therefore  faster,  instructions.  However,  input/output  mstructions  have 
two  disadvantages. 

First,  they  "waste"  several  of  the  precious  few  opcodes  available 
(since  usually  only  8  bits  are  used  to  supply  all  opcodes  necessary  for  a 
microprocessor).  Secondly,  they  require  the  generation  of  one  or  more 
specialized  input/output  signals,  and  therefore  "waste"  one  or  more  of 
the  few  pms  available  in  the  microprocessor.  The  number  of  pins  is 
usually  limited  to  40.  Because  of  these  possible  disadvantages,  specific 
mput/output  instructions  are  not  provided  on  most  microprocessors. 
They  are,  however,  provided  on  the  original  8080  (the  first  powerful 
eight-bit  general-purpose  microprocessor  introduced)  and  on  the  Z80, 
which  we  know  is  compatible  with  the  8080. 

The  advantage  of  input/output  instructions  is  to  execute  faster  by  re- 
quiring only  two  bytes.  However,  a  similar  result  can  be  obtained  by 
supplying  a  special  addressing  mode  called  "page  0"  addressing,  where 
the  address  is  limited  to  a  field  of  eight  bits.  This  solution  is  often 
chosen  m  other  microprocessors. 

The  two  basic  input/output  instructions  are  IN  and  OUT.  They 
transfer  either  the  contents  of  the  specified  I/O  locations  into  any  of 
the  workmg  registers  or  the  contents  of  the  register  into  the  1/0  device. 
They  are  naturally  two  bytes  long.  The  first  byte  is  reserved  for  the  op- 
code, the  second  byte  of  the  instruction  forms  the  low  part  of  the  ad- 
dress. The  accumulator  is  used  to  supply  the  upper  part  of  the  address. 
It  is  therefore  possible  to  select  one  of  the  64K  devices.  However,  this 
requires  that  the  accumulator  be  loaded  with  the  appropriate  contents 
every  time,  and  this  may  slow  the  execution. 

In  the  register-input  mode,  whose  format  is  IN  r,  (C),  the  register 
pair  B  and  C  is  used  as  a  pointer  to  the  I/O  device.  The  contents  of  B 
are  placed  on  the  high-order  part  of  the  address  bus.  The  contents  of 
the  specified  I/O  device  are  then  loaded  into  the  register  designated  by 
r. 

The  same  applies  to  the  OUT  instruction. 

Additionally,  the  Z80  provides  a  register-indirect  mode,  plus  four 
specialized  block-transfer  instructions  for  input  and  output. 

The  four  block-transfer  instructions  on  input  are:  INI,  INIR 
(repeated  INI),  IND  and  INDR  (repeated  IND),  Similarly,  on  output. 
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they  are:  OUTI,  OTIR,  OUTD.  and  OTDR. 

In  this  automated  block  transfer,  the  register  pair  H  and  L  is  used  as 
a  destination  pointer.  Register  C  is  used  as  the  I/O  device  selector  (one 
out  of  256  devices).  In  the  case  of  the  output  instruction,  H  and  L  point 
to  the  source.  Register  B  is  used  as  a  counter  and  can  be  incremented 
or  decremented.  The  corresponding  instructions  on  input  are  INI 
when  incrementing  and  IND  when  decrementing. 

IMl  re  an  automsited  smgie-feyte  transfer.  Register  C  selects  the  input 
device.  A  byte  is  read  from  the  device  and  is  transferred  to  the  memory 
address  pointed  to  by  H  and  L.  H  and  L  are  then  incremented  by  1 ,  and 
the  counter  B  is  decremented  by  I. 

INIR  is  the  same  instruction,  automated.  It  is  executed  repeatedly 
until  the  counter  decrements  to  "0",  Thus,  up  to  256  bytes  may  be 
transferred  automatically.  Note  that  to  achieve  a  total  transfer  of  exact- 
ly 256,  register  B  should  be  set  to  the  value  "0"  prior  to  executing  this 
instruction.  , 

The  opcodes  for  the  input  and  output  instructions  are  summarized  in 
Figures  4.20  and  4.21. 

Control  Instructions 

Control  instructions  are  instructions  which  modify  the  operating 
mode  of  the  CPU  or  manipulate  its  internal  status  information.  Seven 
such  instructions  are  provided. 

The  NOP  instruction  is  a  no-operation  instruction  which  does 
nothing  for  one  cycle,  it  is  typically  used  either  to  introduce  a  deliberate 
delay  (4  states  =  2  microseconds  with  a  2MHz  clock),  or  to  fill  the  gaps 
created  in  a  program  during  the  debugging  phase.  In  order  to  facilitate 
program  debugging,  the  opcode  for  the  NOP  is  traditionally  all  O's. 
This  is  because,  at  execution  time,  the  memory  is  often  cleared,  i.e.,  ail 
O's,  Executing  NOP's  is  guaranteed  to  cause  no  damage  and  will  not 
stop  the  program  execution. 

The  HALT  instruction  is  used  in  conjunction  with  interrupts  or  a 
reset.  It  actually  suspends  the  operation  of  the  CPU.  The  CPU  will  then 
resume  operation  whenever  either  an  interrupt  or  a  reset  signal  is  re- 
ceived. In  this  mode,  the  CPU  keeps  executing  NOP's.  A  haU  is  often 
placed  at  the  end  of  programs  during  the  debugging  phase,  as  there  is 
usually  nothing  else  to  be  done  by  the  main  program.  The  program 
must  then  be  explicitly  restarted. 

Two  specialized  instructions  are  used  to  disable  and  enable  the  inter- 
nal interrupt  flag.  They  are  EI  and  DI.  Interrupts  will  be  described  in 
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SEGISTEa 

REG. 
IND. 

A 

C 

0 

E 

H 

L 

!HU 

■our 

IMMEO. 

(n! 

OZ 
ft 

REO. 
INO. 

ICJ 

ED 
79 

ED 
^1 

ED 

EO 

ED 

ED 

eo 

■OUTi'  -  aUTf  UT 
Ine  HL.,  {>>c  b 

REG. 
INO. 

IC) 

EO 
A3 

'PTIB'  -  OUTPUT,  IBO  Hi., 
OieG,  REPEAT  <FG«> 

INO. 

ICI 

ED 
53 

■OUTO'  -OUTPUT 
0>CHU&  B 

REG. 

mo. 

ICI 

ED 
AB 

•OTDB-  -  OUTPUT.  Die  HS. 
4  B,  HEPEAT  f  F  B*0 

iND. 

IC! 

ED 
SB 

PORT 

DESTIHATION 
ADDRESS 


Fig.  4.20:  Oulput  Group 


SLOCK 

>ouTrifr 

COMMANDS 


SOURCE 
PORT  ADDRESS 


INPUT 

DESTINATION 


IC) 

A 

n 

EO 
7S 

fl 

EO 
4Q 

f, 

A 

C 

EO 

<e 

□ 

R 

□ 

ED 
50 

i 
1 

fi 

£D 

5a 

G 

H 

£Q 
EC 

i 

ta 

Ed 
« 

-\nm--ittp  in^m. 

D^b,  BtPf  AT  IF  B'O 

R£C 

ED 

Ote  Hi..  Ore  a 

£□ 

^^^D^^■-!H^^JT  hl 
Ok  a.  airiMtif  bHj 

£a 

SA 

>  BLOCK  INPUT 
COMMANDS 


Fig.  4.21;  Input  Group 
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Chapter  6.  The  interrupt  flag  is  used  to  authorize  or  not  authorize  the 
interruption  of  a  program.  To  prevent  interrupts  from  occurring  during 
any  specific  portion  of  a  program,  the  interrupt  flip-flop  (flag)  may  be 
disabled  by  this  instruction.  It  will  be  used  in  Chapter  6.  These  in- 
structions are  shown  in  Figure  4.22. 


'NOP' 

'HALT' 

lifts- 

^^^^^^^ 

DISABLE  INT'{Dir 

ENABLE  INT  'SEIi' 

^^^^^ 

SET  INT  MODE  0 

EO 
46 

SETINT  M0DE1 
■|M1' 

ED 
56 

SETINT  MODE  2 

ED 
5E 

8080A  MODE 


INDIRECT  CALL  USING  REGISTER 
I  AND  8  BITS  FROM  INTERRUPTING 
DEVICE  AS  A  POINTER. 


Fig.  4.22:  Miscellaneous  CPU  Control 


Finally,  three  interrupt  modes  are  provided  in  the  Z80.  (Only  one  is 
available  on  the  8080).  Interrupt  mode  0  is  the  8080  mode,  interrupt  1  is 
a  call  to  location  038H,  and  interrupt  mode  2  is  an  indirect  call  which 
uses  the  contents  of  the  special  register  1,  plus  8  bits  provided  by  the  in- 
terrupting device  as  a  pointer  to  the  memory  location  whose  contents 
are  the  address  of  the  interrupt  routine.  These  modes  will  be  explained 
in  Chapter  6. 

which  will  also  be  explained  in  Chapter  6.  They  are  the  IRQ  and  the 
NMI  pins. 
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SUMMARY 

The  five  categories  of  instructions  availabie  on  the  Z80  have  now 
been  described.  The  details  on  individual  instructions  are  supplied  in 
the  foilov/ing  section  of  the  book.  It  is  not  necessary  to  understand  the 
role  of  each  instruction  in  order  to  start  to  program.  The  knowledge  of 
a  few  essential  instructions  of  each  type  is  sufficient  at  the  beginning. 
However,  as  you  begin  to  write  programs  by  yourself,  you  should  learn 
about  all  the  instructions  of  the  Z80  if  you  want  to  write  good  pro- 
grams. Naturally,  at  the  beginning,  efficiency  is  not  important,  and  this 
is  why  most  instructions  can  be  ignored. 

One  important  aspect  has  not  yet  been  described.  This  is  the  set  of 
addressing  techniques  implemented  on  the  Z80  to  facilitate  the  retrieval 
of  data  within  the  memory  space.  These  addressing  techniques  will  be 
studied  in  the  next  chapter. 
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THE  Z80  INSTRUCTIONS:  INDIVIDUAL  DESCRIFnON 


ABBREVIATIONS 


FLAG 

ON 

OFF 

Carry 

C  (carry) 

NC  (no  carry) 

Sign 

M  (minus) 

P  (plus) 

Zero 

Z (zero) 

NZ  (non  zero) 

Parity 

PE  (even) 

PO{odd) 

O  changed  functionally  according  to  operation 

0  flag  is  set  to  zero 

1  flag  is  set  to  one 

?  flag  is  set  randomly  by  operation 

X  special  case,  see  accompanying  note  on  that  page 

bit  positions  3  and  5  are  always  random 
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ADCA,s 

Function: 
Formal: 


Add  accumulator  and  specified  operand  with 
carry. 

A  ^  A  +  s  +  C 

s;  may  be  r,  n,  (HL),(IX  +  d),  or  (lY  +  d) 


(HL) 
(IX  +  d) 


(lY  +  d) 


I 

0  0 

0 

i 

 1  "T  

t  i 

1 

0 

( 

i 

i 

0 

_J  I  I  L. 


byte  1:  CE 

byte  2:  immediate 
data 

8E 

byte  1;  DD 


I       I  I  !  I  I  ' 


byte  1:  FD 

byte  2:  8E 

byte  3:  offset  value 


r  may  be  any  one  of: 

A  -  111  E  -  Oil 

B  -  000  H  -  100 

C  -  001  L  -  101 
D  -  010 
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Description: 


Data  Flo  w: 


The  operand  s  and  the  carry  flag  C  from  the  status 
register  are  added  to  the  accumulator,  and  the 
result  is  stored  in  the  accumulator,  s  is  defined  m 
the  description  of  the  similar  ADD  instructions. 


_  ^     A  \ 

\  V 

\  ALU 

\      +c  / 

c 

E 
L 

Timing: 


Addressing  Mode: 


Byte  Codes: 


Flags: 
Example: 


usee 

s: 

M  cycles: 

T states: 

@  2  MHz: 

r 

1 

4 

2 

n 

2 

1 

3.5 

(HL) 

2 

7 

3.5 

(IX  +  d) 

5 

19 

9.5 

(ly  -f  d) 

5 

19 

9.5 

r:  implicit;  n:  immediate;  (HL):  indirect;  (IX  -f- 
d),  (lY  +  d):  indexed. 


ADC   A,r  r. 

A 

8 

C 

0 

E     H  L 

BF 

BB 

89 

BA 

BB  1  8C  j  8D 

S     Z  H 

i)  N 

C 

• 

• 

• 

m 

o 

• 

ADC   A,  iA 


Before: 


After: 


lA 


OBJECT  CODE 


06 


13 
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ADC  HL,  SS       Add  with  carry  HL  and  register  pair  ss. 


Function: 


HL  *™  HL  +  ss  +  C 


Format: 


1 

0 

1 

1 

0 

1 

0 

1 

S  5 

i 

r 

0 

1 

0 

byte  1 ;  ED 
byte  2 


Description: 


Data  Flow: 


SP 


The  contents  of  the  HL  register  pair  are  added  to 
the  contents  of  the  specified  register  pair,  and  then 
the  contents  of  the  carry  flag  are  added.  The  final 
result  is  stored  back  in  HL.  ss  may  be  any  one  of; 


BC  -  00 
DE  -  01 


HL  -  10 
SP  ™  11 


Timing:  4  M  cycles;  15  T  states:  75  usee  @  2  MHz 

Addressing  Mode:  Implicit. 


Byte  Codes: 


ss: 


ec 

DE 

HL 

SP 

4A 

5A 

6A 

7A 
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Flags: 


Example: 


s 

z 

H 

c 

• 

1  '  1 

• 

O 

• 

H  is  set  if  there  is  a  carry  from  bit  i  1 . 
ADC    HL,  DE 


Before: 


After: 


ED 


5A 


OBJECT 
CODE 


329! 


0F18 
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ADD  A,  (HL)     Add    accumulator    with    indirectly  addressed 
memory  location  (HL), 


Function: 
Formal; 


A     A  +  (HL) 


1 

0 

0 

0 

0 

1 

1 

0 

86 


Description:  The  contents  of  the  accumulalor  are  added  to  the 

contents  of  the  memory  iocauon  addressed  by  the 
HL  register  pair.  The  result  is  stored  m  the  ac- 
cumulator. 


Da  la  Flow: 


DATA 


MEMORY 


Timing: 


2  M  cycles;  7  T  stales:  3.5  usee  @  2  MHz 


Addressing  Mode:  indirect. 


Flags: 


5 

z 

P/®  N 

c 

9 

• 

m 

o 
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Example: 


ADD    A,  (HL) 


Before: 


After: 


02 


9620 


9620 
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ADD  A,  (IX  +  d)     Add  accumulator  with  indexed  addressed 

memory  location  (IX  +  d) 


Function: 
Format: 


A  *-  A  +  (IX  +  d) 


1 — 1  1  i  1  i  r- 

  d  

_l  I  !  \  i  I  U 


byte  1 ;  DD 

byte  2:  86 

byte  3:  offset  value 


Description:  The  contents  of  the  accumulator  are  added  to  the 

contents  of  the  memory  location  addressed  by  the 
contents  of  the  IX  register  plus  the  immediate  off- 
set value.  The  result  is  stored  m  the  accumulator. 


Data  Flow: 


Timing: 


) 

ADD 

d 

5  M  cycles;  19  T  states:  9,5  usee  @  2  MHz 


Addressing  Mode:  Indexed 
Flags: 


s 

1 

H 

H 

c 

9 

m 

% 

• 

o 

9 
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Example: 


ADD    A,  (IX  4-  3) 


Before: 


After: 


0B6! 


0B6i 


DD 


86 


03 


OBJECT  CODE 


0B6I 

04 

0B61 

OA 

0662 

B2 

0B62 

B2 

0B63 

36 

0B63 

36 

0B6'< 

91 

0B64 

91 
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ADD  A,  (lY  +  d)      Add  accumulator  with  indexed  addressed 

memory  location  (iY  +  d) 


Function: 
Format: 


Description: 


Data  Flow: 


A     A  +  (IY  +  d) 


I  I 


1 

a 

□ 

0 

0 

i 

i 

0 

J — J — i- 


-1  1  i  r 

d   

_J  1  !  L. 


byte  I :  FD 

byte  2:  86 

byte  3:  offset  value 


The  contents  of  the  accumulator  are  added  to  the 
contents  of  the  memory  location  addressed  by  the 
contents  of  the  IY  register  plus  the  given  offset 
value.  The  result  is  stored  m  the  accumulator. 


DATA 


) 

LD 

d 

ADD 

Timing: 


5  M  cycles;  19  T  states;  9.5  usee  @  2  MHz 


Addressing  Mode:  Indexed 
Flags: 


s 

z 

H 

c 

• 

• 

• 

• 

o 

9 
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Example: 


ADD    A,  (lY  +  i) 


Before: 


After: 


31 


002B 


IX 


O02B 


FD 


01 


OBJECT 
CODE 


0O2B 
002C 


06 


9A 


QQ2B 
Q02C 


06 
9A 
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ADD  A,  n 


Add  accumulator  with  immediate  data  n. 


Function: 
Formal: 


A  ^  A  +  n 


Description: 


Data  Flo  w: 


T  1  1  1  1  r 


_!  I  I  I  I  I  L. 


byte  i:  C6 

byte  2:  immediate 
data 


The  contents  of  the  accumulator  are  added  to  the 
contents  of  the  memory  location  immediately 
following  the  op  code.  The  result  is  stored  in  the 
accumulator. 


MEMORY 


Timing: 


2  M  cycles;  7  T  states:  3.5  usee  @  2  MHz 


Addressing  Mode:  Immediate. 
Flags: 


Example: 


Ob 


E2 


OBJEa  CODE 


5 

2 

H 

P/®  N 

C 

• 

• 

• 

o 

• 

ADD  A,  E2 
Before: 


43 


After: 
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ADD  A,  r 

Function: 
Format: 


THE  Z80  INSTRUCTION  SET 
Add  accumulator  with  register  r. 

A  *-  A  -I-  r 


Description:  The  contents  of  the  accumulator  are  added  with 

the  contents  of  the  specified  register.  The  result  is 
placed  in  the  accumulator,  r  may  be  any  one  of: 


A  -  111 
B  -  000 
C  -  DDI 
D  -  010 


E  ~  Oil 
H  -  100 
L  -  101 


Data  Flow: 


Timing:  1  M  cycle;  4  T  states:  2  usee  @  2  MHz. 

Addressing  Mode:  Implicit. 


Byte  Codes:  r: 

A 

B 

C 

D 

E 

H 

L 

B7 

80 

B\ 

Bl 

83 

B4 

85 

Flags: 

S 

Z 

H 

P/® 

N 

c 

• 

• 

• 

• 

o 

• 
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Example: 


ADD   A,  B 


Before: 


After: 


80 


OBJEa  CODE 


3D 


B  02 


6  02 
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ADD  HL,  SS       Add  HL  and  register  pair  ss. 


Function: 
Format: 

Description: 


HL  *-  HL  +  ss. 


0     0     S  ,  S      I      0  0 


The  contents  of  the  specified  register  pair  are 
added  to  the  contents  of  the  HL  register  pair  and 
the  result  is  stored  in  HL.  ss  may  be  any  one  of: 


BC 
DE 


00 
01 


HL  -  10 
SP  -  11 


Data  Flow: 


wmmmm 

mmmm 

SP 


Timing:  3  M  cycles;  11  T  states:  5.5  usee  @  2  MHz 

Addressing  Mode:  Implicit. 
Byte  Codes: 


ss: 


BC 

DE 

HL 

SP 

09 

19 

29 

39 

Flags: 


5 

Z 

H 

P/V 

N 

C 

9 

o 

• 

C  is  set  by  carry  from  bit  15,  reset  otherwise. 
His  set  by  a  carry  from  bit  11 
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Example:  ADD   HL,  HL 

Before: 


29 
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ADD  IX,  rr         Add  IX  with  register  pair  rr. 


Function: 
Format: 


iX  -  IX  +  rr 


s 

) 

0 

1 

1 

i 

0 

1 

0 

0 

I 
1 

1 

0 

0 

1 

byte  1:  DD 


I   byte  2 


Description:  The  contents  of  the  IX  register  are  added  to  the 

contents  of  the  specified  register  pair  and  the 
result  is  stored  back  in  IX.  rr  may  be  anyone  of: 


BC  -  00 
DE  -  01 


IX  -  10 
SP  -  11 


Data  Flo  w: 


Timing: 


4  M  cycles;  15  T  states;  7.5  usee  @  2  MHz 


Addressing  Mode:  implicit. 


09 

!<? 

29 

39 
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s 

z 

H 

P/V 

N 

C 

1 

o 

• 

H  is  set  by  carry  out  of  bit  1 1 . 
C  is  set  by  carry  from  bit  15. 


Example:  ADD    IX,  SP 


Before:  After: 


OBJECT 
CODE 
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ADD  lY,  rr         Add  lY  and  register  pair  rr. 


Function: 
Formal: 


Descnplton: 


lY      lY  +  rr 

I  I  1  j  I  I  ^  I  «  j  i  j  0  I  I  I  byte  1 :  FD 

byte  2 


The  contents  of  the  lY  register  are  added  to  the 
contents  of  the  specified  register  pair  and  the 
result  IS  stored  back  in  lY,  rr  may  be  any  one  of: 


BC 
DE 


00 
01 


lY 
SP 


10 

n 


Datg  Flow: 


Timing: 


4  M  cycles;  15  T  states:  7.5  usee  @  2  MHz 


Addressing  Mode:  implicit 
Byte  Codes: 


rr: 

BC 

OE 

1Y 

SP 

FD- 

09 

19 

29 

39 
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Flags: 


5  Z 


P/V   N  C 


1  lo 

H  is  set  by  carry  out  of  bit  1 1 . 
C  Is  set  by  carry  out  of  bit  15. 


Example: 


ADD    lY.  DE 


Before; 


After; 


FD 


19 


OBJEa 
CODE 


6122 


iY 


3051 


6122 
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AND  s 


Logical  AND  accumulator  with  operand  s. 


Function: 
Format: 


AAs 

s:  may  be  r,  n.  (HL),  (IX  +  d),  or  (lY  +  d) 


r 

1 

0 

1 

0 

0 

i  1 

f   ^  1 

n 

1 

1 

1 

0 

0 

i 

0 

-J      f      [      I      [     '  1  r' 


J  !  (  I  !  I  !_ 


(HL) 
(IX  -f  d) 


j        j  I 


(lY  +  d) 


■"(  I"  1  1  J  r~ 


_1  I  I  I  \  I  L. 


r  may  be  any  one  of: 


byte  1 :  E6 

byte  2:  immediate 
data 

A6 

byte  1:  DD 

byte  2:  A6 

byte  3:  offset  value 

byte  1 :  FD 

byte  2:  A6 

byte  3:  offset  value 


A  -  111 
B  -  000 
C  -  001 
D  -  010 


E  -  on 

H  -  100 
L  -  101 


Description: 


The  accumulator  and  the  specified  operand  are 
logically  'and'ed  and  the  result  is  stored  in  the  ac- 
cumulator, s  is  defined  in  the  description  of  the 
similar  ADD  instructions. 
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Dala  Flow: 


Timing: 


usee 

s: 

M  cycles: 

T  states: 

r 

! 

4 

2 

n 

2 

7 

3.5 

(HL) 

7 

3.5 

(IX  +  d) 

5 

19 

9.5 

{lY  +  d) 

5 

19 

9.5 

Addressing  Mode:    r:  implicit;  n:  immediate;  (HL):  indirect;  (IX  + 
d),  (lY  +  d):  indexed. 


Byte  Codes: 


AND 


r 

A 

a 

c 

D 

E 

H 

L 

A7 

AO 

M 

A2 

A3 

A4 

A5 

Flags: 


s   z       H     Qy^  N  c 


• 

• 

i 

9 

o 

o 

Example: 


AND  4B 
Before: 


After: 


36 
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BIT  b,  (HL)       Test  bit  b  of  indirectly  addressed  memory  location 
(HL) 


Function: 


Formal: 


Description: 


1 

1 

0 

0 

i 

0 

\ 

( 

_J  p. 

— b— 

J  L 


byte  1:  CB- 
byte  2 


The  specified  bit  of  the  memory  location  address- 
ed by  the  contents  of  the  HL  register  pair  is  tested 
and  the  Z  fiag  is  set  according  to  the  result,  b  may 


be  any  one  of: 

0-000 

4  ~ 

100 

1  -  001 

5  - 

101 

2  ~  010 

6  - 

110 

3  -  Oil 

7 

111 

Data  Flow: 

A 


m 

Timing:  3  M  cycles;  12  T  states;  6  usee  @  2  MHz 

Addressing  Mode:  Indirect. 


Flags: 


s  z 


P/V  N  C 
?  0 
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Byte  Codes: 


b: 

CB-  n*  56    5E    tb    6E    76  7E 


Example: 


BIT  3,  (HL) 
Before: 


After: 


00 


6A42 


C6 
5E 


6A42 


OS 


6A42 


05 


OBJECT  CODE 
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BIT  b,  (IX  -I-  d)  Test  bit  b  of  indexed  addressed  memory  location 
(IX  +  d) 


Function: 
Format: 


Z      (iX  +  d)ij 


_l  1  1  1  1  1  5- 

  d   

J  [  1  1  1  I  l_ 


1      i  0 


byte  1:  DD 
byte  2:  CB 
byte  3:  offset  value 
byte  4 


Descnptton:  The  specified  bit  of  the  memory  location  address- 

ed by  the  contents  of  the  IX  register  plus  the  given 
offset  value  is  tested  and  the  Z  flag  is  set  according 
to  the  result,  b  may  be  any  one  of: 

0  ~  0(M)  5-101 

1  -  001  6-110 
2-010  7  -  111 

3  -  on 

4  -  100 
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Timing:  5  M  cycles;  20  T  states;  10  usee  @  2  MHz 

Addressing  Mode:  Indexed. 
Byte  Codes: 


b:  0 
OD-CB-d- 


2     3     4     5     6  7 


Flags: 


4E 

56 

5E 

66 

6E 

76 

7E 

s  z 


P/V  N  C 


Example: 


BIT  6,  (IX  +  0) 
Before; 


After: 


AA!i 


IX 


AAll 
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BIT  b,  (lY  +  d)  Test  bit  b  of  the  indexed  addressed  memory  loca- 
tion (lY  +  d) 


Function: 
Format: 


Z  -  (lY  +  d)b 


1 

1 

0 

0 

\ 

0 

i 

i 

n — I — I — r 


—  b— 
J  L 


byte  1:  FD 
byte  2:  CB 
byte  3:  offset  value 
byte  4 


Description:  The  specified  bit  of  the  memory  location  ad- 

dressed by  the  contents  of  the  lY  register  plus  the 
given  offset  value  is  tested  and  the  Z  flag  is  set  ac- 
cording to  the  result,  b  may  be  any  one  of: 

0-  000  4  -  100 

1-  001  5  -  lOI 

2-  010  6-110 
3  ^  Oil  7  -  111 
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Timing:  5  M  cycles;  20  T  states:  10  usee  @  2  MHz 


Addressing  Mode:  Indexed. 


Byte  Codes:  b!: 


Flags: 


0 

i 

2 

3 

4 

S 

6 

7 

46 

56 

5E 

66 

6E 

76 

7E 

5 

Z 

H 

P/V 

N 

r 

1 

0 

Example:  BIT   0.  (lY  +  1) 

Before:  After: 

I  If 


FF12 
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BIT  b,  r 


Test  bit  b  of  register  r. 


Function: 


Formal: 


(      t      0     0      !      0  I 


J  L. 


T  r 

—  r  — 
J  L. 


byte  I :  CB 
byte  2 


Description:  The  specified  bit  of  the  given  register  is  tested  and 

the  zero  flag  is  set  according  to  the  results,  b  and  r 
may  be  any  one  of: 


r; 


0 

-  000 

4 

^  100 

1 

-  001 

5 

-  101 

2 

-  010 

6 

™  110 

3 

-  on 

7 

-  lU 

A 

-  lU 

E 

-  on 

B 

-  000 

H 

-  100 

C 

-  001 

L 

-  101 

D 

-  010 

Data  Flow: 


Timing,- 


2  M  cycles;  8  T  states;  4  usee  @  2  MHz 


Addressing  Mode:  Implicit. 
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Byte  Codes; 


CB- 


b: 

:  A 

B 

C 

D 

E 

H 

I 

0 

47 

40 

41 

42 

43 

44 

45 

! 

4F 

48 

49 

4A 

4B 

4C 

4D 

2 

S7 

50 

51 

52 

53 

54 

55 

Sf 

58 

59 

SA 

58 

5C 

5D 

4 

67 

60 

61 

62 

63 

64 

65 

5 

6F 

68 

69 

6A 

6B 

6C 

60 

6 

77 

70 

71 

72 

73 

74 

75 

7 

7F 

78 

79 

7A 

78 

7C 

70 

Flags: 


S     Z  H         P/V   N  C 


Example: 


BIT   4.  B 


Before: 


After: 


B  41 


01  F   61 


CB 
60 


OBJEa  CODE 
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CALL  CC,  pq      Call  subroutine  on  condition. 


Function: 


if  CC  true:  {SP  - 
PCio^v;  SP     SP  - 
I  fee  false:  PC  -  PC  +  3 


n  -  PCh,gh; 
2;  PC  ^  pq 


(SP 


2) 


Format: 


1 

i 

■■"  1  t 

1 

0 

0 

 1  1 

1  ■  1 

1  1 

 q  

i  1 

i  1 

i  1 

1  1 

(  1 

(    [     1     1     1     1  1 

byte  i 

byte  2:  address, 
low  order 
byte  3;  address, 
high  order 


Description:  if  the  condition  is  met,  the  contents  of  the  pro- 

gram counter  are  pushed  onto  the  stack  as  de- 
scribed for  the  PUSH  instructions.  Then,  the  con- 
tents of  the  memory  location  immediately  Follow- 
ing the  opcode  are  loaded  into  the  low  order  of  the 
PC  and  the  contents  of  the  second  memory  loca- 
tion after  the  the  opcode  are  loaded  into  the  high 
order  half  of  the  PC.  The  next  instruction  fetched 
will  be  from  this  new  address.  !f  the  condition  is 
not  met,  the  address  pq  is  ignored  and  the  follow- 
ing instruction  is  executed,  cc  may  be  any  one  of: 


NZ 

-  000 

PO  - 

100 

Z 

-  001 

PE  - 

101 

NC 

-  010 

P  - 

!00 

C 

-  oil 

M  ^ 

ill 

An  RET  instruction  can  be  used  at  the  end  of  the 
subroutine  being  called  to  restore  the  PC. 
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Data  Flow: 


Timing: 


M  cycles: 

T  stales: 

usee 
@  2  MHz 

condition 

true: 

5 

17 

8.5 

condition 

not  true: 

3 

10 

5 

Addressing  Mode:  immediate 
Byle  Codes: 


Flags: 


N2 

.  1 

NC 

C 

PO 

PE 

P 

M 

C4 

cc 

D4 

DC 

E. 

EC 

F4 

EC 

S 

z 

H 

P/V 

N 

C 

1 

(no  effect) 
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Example:  CALL    Z,  B042 

Before:  After: 


I        85       "I  F  I        85       "]  f 
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CALL  pq 

Function: 

Format: 


Call  subroutine  at  location  pq. 


{SP  -  l)*-PChigh;(SP 
-  2;  PC  pq 


E 


.  i  1  i  L 


2)     PCjovv;  SP  *-  SP 
byie  1:  CD 

byte  2:  address,  low  order 
byte  3:  address,  high  order 


Descripiion:  The  contents  of  the  program  counter  are  pushed 

onto  the  stack  as  described  for  the  PUSH  instruc- 
tions. The  contents  of  the  memory  location  im- 
mediately following  the  opcode  are  then  loaded  in- 
to the  low  order  half  of  the  PC  and  the  contents  of 
the  second  memory  location  after  the  opcode  are 
loaded  in  the  high  order  half  of  the  PC.  The  next 
instruction  will  be  fetched  from  this  new  address. 


Data  Flow: 


Timing: 


5  M  cycles;  17  T  states:  8.5  usee  @  2  MHz 


Addressing  Mode:  Immediate. 
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Flags: 


S     Z  H         P/V  N  C 


(no  effect) 


Example: 


CALL  40B1 


Before: 


After: 


PC  j 
SP  I 


AA10 


OSM 


CD 


Bl 


40 


OBJECT  CODE 


0B12 
DB13 
0B14 


9A 


01 


F4 


OB52 
0Si3 
0B14 


F4 
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Complement  carry  flag. 


CCF 

Function: 
Format: 

Description: 
Data  Flow: 


C  *-C 


i  I 


3F 


The  carry  flag  is  complemented. 


ALU 


Timing:  1  M  cycle;  4  T  states:  2  usee  @  2  MHz 

Addressing  Mode:    Implicit.  . 

Flags: 


s 

z 

H 

N 

c 

O 

• 
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Compare  operand  s  to  accumulator. 


Function: 
Formal: 


(HL) 
(IX  +  d) 


(lY  +  d) 


A  -  s 

s:  may  be  r,  n.  (HL),  (IX  +  d),  or  (lY  +  d). 


—%  r- 

— r — - 
_j  i_ 


"1  1  J  r 


.  I  .      1  ]  I  ]  i  L_ 


i 

0 

1 

1 

1 

f 

1 

0 

"1  1  1  1  r I 


_J  [  I  1  L- 


FE 

byte  2:  immediate 
data 

byte  i:  BE 
byte  i:  DD 
byte  2:  BE 

byte  3:  offset  value 
byte  I :  FD 
byte  2:  BE 

byte  3:  offset  value 


r  may  be  any  one  of: 


A  -  111 
B  -  000 
C  -  001 
D  -  010 


E  -  on 

H  -  100 
L  -  101 


Description:  The  specified  operand  is  subtracted  from  the  ac- 

cumulator, and  the  result  is  discarded,  s  is  defined 
in  the  description  of  the  similar  ADD  instructions. 
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Data  Flow: 


Timing: 


s: 

M  cycles: 

T  states: 

usee 
@  2  MHz: 

r 

i 

4 

2 

n 

2 

7 

3.5 

(HL) 

t 

7 

3.5 

(IX  +  d) 

5 

19 

9.5 

(lY  +  d) 

5 

19 

9.5 

Addressing  Modes:   r:  implicit;  n:  immediate;  (HL):  indirect; 

(iX  +  d),  (lY  +  d):  indexed 


Byte  Codes: 
Flags: 


CP  r 


s  z 


r:  n 

A 

B 

c 

D 

E 

H 

L 

BF 

BB 

B9 

BA 

BB 

BC 

BD 

PXgi  N  C 


Example: 


CP  (HL) 
Before: 


hI  


8203 


After: 


BE 


B203 


42 


8203 


42 
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CPD 


Compare  with  decrement. 


Function: 
Format: 


A  — [HL];HL— HL— J;BC  — BC—l 


i 

i 

i 

0 

1 

1 

0 

1 

1 

0 

1 

0 

i 

0 

o|  , 

byte  1:  ED 


Description:  The  contents  of  the  meniory  location  addressed  by 

the  HL  register  pair  are  subtracted  from  the  con- 
tents of  the  accumulator  and  the  result  is  discarded. 
Then  both  the  HL  register  pair  and  the  BC  register 
pair  are  decremented. 


Data  Flow: 


r  y'f*'  " 

. ./.  .... 

'mmwM 

Timing: 


4  M  cycles;  16  T  states:  8  usee  @  2  MHz 


Addressing  Mode:  indirect. 


Flags: 

S    Z        H      P/V  N  C 


L 


I —  Reset  ifBC  =  0  after  execution;  set  otherwise 
JjSetif  A  =  [HL] 
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Example:  CPD 

Before:  After: 


ED 


B6B5 


2A 


8685 


2A 


OBJECT  CODE 
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CPDR 


Block  compare  with  decrement. 


Function: 


Format: 


A  — [HL];HL*~  HL— 1;  BC-^  BC  —  i; 
Repeat  until  BC  =  OorA  =  [HL] 


j 

! 

i 

0 

1 

1 

0 

1 

1 

0  j  1 

i 

1 

0 

0 

[ 

bytel:  ED 
byte  2:  B9 


Description:  The  contents  of  the  memory  location  addressed  by 

the  HL  register  pair  are  subtracted  from  the  con- 
tents of  the  accumulator  and  the  result  is  discard- 
ed. Then  both  the  BC  register  pair  and  the  HL 
register  pair  are  decremented.  If  BC  0  and  A  ?i 
[HL],  the  program  counter  is  decremented  by  two 
and  the  instruction  is  re-executed. 


Data  Flow: 


Timing: 


Flags: 


BC  =  0  or  A  =  [HLj:  4  M  cycles;  16  T  states: 
8  usee  @  2  MHz 

BC  #  0  and  A  #  [HL]:  5  M  cycles;  21  T  states; 
10.5  usee  @  2  MHz 


P/V  N 


-Reset  if  BC  =  0  after 
execution;  set  otherwise 

J  Set  if  A  =  [HL] 
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Example:  CPDR 

Before:  After: 


ED 
B9 


OBJEa  CODE 


60FE 

08 

60FE 

QB 

60FF 

00 

60FF 

00 

6100 

2A 

6100 

2A 
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CPI 


Compare  with  increment. 


Function: 
Format: 


A  — f.HL];HL^  HL  +  1;BC  *-BC— i 


I      I      I      0      I      I      0  I 


0  I 


0  0 


0  0 


byte  i :  ED 
byte  2:  Al 


Description:  The  contents  of  the  memory  location  addressed  by 

the  HL  register  pair  are  subtracted  from  the  con- 
tents of  the  accumulator  and  the  result  is  discarded. 
The  HL  register  pair  is  incremented  and  the  8C 
register  pair  is  decremented. 


Data  Flow: 


Timing:  4  M  cycles;  16  T  states;  8  usee  @  2  MHz 

Addressing  Mode:  indirect. 


Flags: 


s  z 


P/V  N  C 


—  Reset  ifBC  =  0  after  execution  set  otherwise 
J- Set  if  A  =  [HL] 
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Example:  CPI 

Before:  After: 


OBJEa  CODE 
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CPIR 


Block  compare  with  increment. 


Function: 


A  —  [HL];  HL  HL  +  1;  BC  ^  BC  —  1; 
Repeat  until  BC  =  0  or  A  =  [HL] 


byte  1:ED 


i    0   0   0    I  byte2:Bi 


Description:  The  contents  of  the  memory  location  addressed  by 

the  HL  register  pair  are  subtracted  from  the  con- 
tents of  the  accumulator  and  the  result  is  discarded. 
Then  the  HL  register  pair  is  incremented  and  the 
BC  register  pair  is  decremented.  If  BC  0  and  A 
^  [HL],  then  the  program  counter  is  decremented 
by  2  and  the  instruction  is  re-executed. 


Data  Flow: 


4 

DATA 



Timing: 


BC  =  0  or  A  =  [HL]  :  4  M  cycles;  16  T  states: 
8  usee  @  2  MHz 

BC  7^  0  and  A  ?^  [HL] :  5  M  cycles;  21  T  states: 
10.5  usee®  2  MHz 


Addressing  Mode:  indirect. 
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Flags: 

S    2        H      P/V  N  C 


J—  Reset  ifBC  =  0  after  execution;  set  otherwise 
Jj  Set  if  A  =  [HL] 


Example:  CPIR 


Before:  After; 
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CPL 


Complemenl  accumulator. 


Fund  ion: 
Formal: 

Description: 


0 

0 

1 

0 

1 

1 

1 

I 

The  contents  of  the  accumulator  are  com- 
plemented, or  inverted,  and  the  result  is  stored 
back  in  the  accumulator  {one's  complement). 


Data  Flow: 


Timing: 


1  M  cycle;  4  T  states;  2  usee  @  2  MHz 


Addressing  Mode:  Implicit. 


Flags: 


S     Z  H         PA'  N  C 


Example: 


2F 


OBJECT 
CODE 


CPL 
Before: 


A  3D 


After; 


235 


PROGRAMMING  THE  Z80 


Decimal  adjust  accumulator. 


Function: 


See  below. 


Format: 


0    a    i    0    0    i    i    I  27 


Description:  The  instruction  conditionally  adds  "6"  to  the  right 
and/or  left  nibble  of  the  accumulator,  based  on  the 
status  register,  for  BCD  conversion  after  arithmetic 
operations. 


value  of 

value  of 

#  added 

C  after 

N 

C 

high  nibble 

H 

low  nibble 

to  A 

execution 

0 

0-9 

0 

0-9 

00 

0 

(ADD, 

0 

0-8 

0 

A-F 

06 

0 

ADC, 

0 

0-9 

1 

0-3 

06 

0 

INC) 

0 

A-F 

0 

0-9 

60 

0 

9-F 

0 

A-F 

66 

0 

A-F 

i 

0-3 

66 

1 

0-2 

0 

0-9 

60 

1 

0-2 

0 

A-F 

66 

1 

0-3 

i 

0-3 

66 

1 

0 

0-9 

0 

0-9 

00 

0 

(SUB, 

0 

0-8 

1 

6-F 

FA 

0 

SBC, 

1 

7-F 

0 

0-9 

AO 

1 

DEC, 

I 

6-F 

1 

6-F 

9A 

1 

NEG) 

Data  Flow; 
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Timing: 


THE  Z80  INSTRUCTION  SET 
i  M  cycle;  4  T  states;  2  usee  @  2  MHz 


Addressing  Mode:  Implicit. 


Flags: 


5     Z  H        0V  N  C 

•I  !• 


Example: 


DAA 


Before: 


After: 


27 


B2 


94         F  A£ 


OBJECT 
CODE 
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DECm 


Decrement  operand  m. 


Function: 


m    m  —  i 


Format: 


m:  may  ber,  (HL),  (IX+d),  (lY+d  ) 


_i  1- 


(HL) 
{IX  +  d) 


_i — I — I — I — I — I — ^ 


-i  i  I  J  t  I  i_ 


(lY  +  d) 


_l  5  1  1  5  5  ^ 


_1  I  1  I  1  1  L. 


35 

byte  1:  DD 

byte  2:  35 

byte  3:  offset  value 

byte  1:  FD 

byte  2:  35 

byte  3:  offset  value 


Description: 


r  may  be  any  one  of: 

A  "111  E-Oli 
B  -  000  H  -  100 

C  -  001  L  -  101 

D  -  010 

The  contents  of  the  location  addressed  by  the 
specific  operand  are  decremented  and  stored  back 
at  that  location. mis  defined  in  the  description  of 
the  similar  INC  instructions. 


Data  Flow. 

A 
B 
D 
H 
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\ 


usee 

m; 

M  cycles: 

T stales: 

@  2  MHz: 

r 

i 

4 

2 

(HLi 

3 

11 

5.5 

(IX  +  dl 

6 

23 

il.5 

(lY  +  d) 

6 

23 

il.5 

Addressing  Mode:    r:  impHcit;  (HL):  indirect;  (IX  +  d),  (!Y  +  d):  in- 
dexed. 


Byie  Codes: 


DEC  r 


r 

r:  A 

e 

c 

D 

E 

H 

L 

1 3D 

OS 

00 

15 

10 

25 

20 

Flags: 


5  z 


H  p/Snc 


Example: 


DEC  C 
Before: 

!  0, — 


Afier: 


OD 
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DEC  rr 


Decrement  register  pair  rr. 


Function: 
Format: 


rr  *-  rr  -  I 


0 

0 

1 

l"  f 
1 

s 

0 

1 

i 

Description:^  The  contents  of  the  specified  register  pair  are 

decremented  and  the  result  is  stored  back  in  the 
register  pair,  rr  may  be  any  one  of: 


BC 
DE 


00 
01 


HL  -  10 
SP  -  11 


Data  Flow: 


Timing: 


J  M  cycie;  6  T  states;  3  usee  @  2  MHz 


Addressing  Mode:  Implicit. 


Byte  Codes:      rr :    bc  de  hi  sp 

OB    IB    2B  33 
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Flags:  5    z         h       p/v  n  c 

(no  effect). 


Example:  DEC  BC 


Before:  After: 


OBJECT  CODE 
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DEC  IX 


Decrement  IX. 


Function: 
Formal: 


Description: 


Data  Flow: 


Timing: 


IX     IX  -  1 


h 

i 

1 

(   j  0 

1 

1° 

»l  ■ 

0 

1 

1 

byte  2;  2B 


The  contents  of  the  iX  register  are  decremented 
and  the  result  is  stored  back  in  IX. 


2  M  cycles;  10  T  states;  5  usee  @  2  MHz 


Addressing  Modes:  Implictt. 
Flags:  s    z       h       p/v  n  c 


(no  effect). 


Example: 


DEC  IX 
Before: 


After; 


iX  6U4 


OBJECT  CODE 
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DEC  lY 


Decrement  lY. 


Fundion: 
Formal: 


!Y     lY  -  1 


Description: 


Data  Flo  w: 


III 

M  1  ,  1  .  1  0  j  , 

0 

0 

,|o 

1 

0 

1 

1 

byte  2:  2B 


The  contents  of  the  lY  register  are  decrementea 
and  the  result  is  stored  back  in  lY, 


Timing:  2  M  cycles;  10  T  states;  5  usee  @  2  MHz 

Addressing  Mode:  Implicit. 


Flags: 


Example: 


SI  H  PA'  N  c 


DEC  lY 
Before: 


lY 


90C1F 


OBJECT  CODE 


(no  effect). 


After: 


iY  r    ;  900E: 
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DI 


Disable  interrupts. 


Function: 
Formal: 

Description: 


IFF^O 


i 

i 

S 

0 

0 

i 

1 

The  interrupt  flip-fiops  are  reset,  thereby  disabling 
all  maskable  interrupts.  It  is  reenabled  by  an  EI 
instruction. 


Timing:  1  M  cycle;  4  T  states;  2  usee  @  2  MHz 

Addressing  Mode:  Implicit. 


Flags: 


SI  H         P/V    N  C 


(no  effect). 
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DJNZ  e 


Decrement  B  and  jump  e  relative  on  no  zero. 


Function: 
Format: 


B  -B  -  nif  B     0:  PC  *-  PC  +  e 


0 

0 

0 

1 

0 

0 

0 

0 

-e-2- 


byte  1;  10 

byte  2:  offset  value 


Description:  The  B  register  is  decremented.  If  the  result  is  not 

zero,  the  immediate  offset  value  is  added  to  the 
program  counter  using  two's  complement 
arithmetic  so  as  to  enable  both  forward  and 
backward  jumps.  The  offset  value  is  added  to  the 
value  of  PC  +  2  (after  the  jump).  As  a  result,  the 
effective  offset  is  -126  to  +129  bytes.  The  as- 
sembler automatically  subtracts  from  the  source 
offset  value  to  generate  the  hex  code. 


Data  Flow: 


Timing: 


B  7^=  0:  3  M  cycles;  13  T  states;  6.5  usee  @  2  MHz. 
B  =  0:  2  M  cycles;  8  T  states;  4  usee  @  2  MHz 


Addressing  Modes:  Immediate. 


245 


PROGRAMMING  THE  Z80 

Flags:  5    z        h       p/v  n  c 

I    I  I  (no  effect) 


Example:  DJNZ    S  -  5    (S  =  current  PC) 

Before:  After: 


OBJECT  com 
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EI 


Enable  interrupts. 


Function: 


IFF  -  1 


Formal: 


I     I     i     I     I    0    I     I  FB 


Description:  The  interrupt  flip-flops  are  set,  thereby  enabling 

maskable  interrupts  after  the  execution  of  the  in- 
struction following  the  EI  instruction.  In  the  mean- 
time maskable  interrupts  are  disabled. 


Timing: 


!  M  cycle;  4  T  states;  2  usee  @  2  MHz 


Addressing  Mode:  Implicit. 


Flags: 


s  z 


p/v  N  c 


(no  effect). 


Example: 


A  usual  sequence  at  the  end  of  an  interrupt  routine  is: 
EI 

RET! 

The  maskable  interrupt  is  re-enabied  foUowmg 
completion  of  RETL 
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EX  AF,  AF'        Exchange  accumulator  and  flags  with  alternate 
registers. 


Function: 


AF-**-AF' 


Format: 


Q     O     O     O      I      O     0     0  08 


Description: 


Data  Flow: 


The  contents  of  the  accumulator  and  status 
register  are  exchanged  with  the  contents  of  the 
alternate  accumulator  and  status  register. 


Timing: 
Addressing  Mode:  Implicit 
Flags:  s  z 


i  M  cycle;  4  T  states;  2  usee  @  2  MHz 


H        P/V  N  c 


9 

9 

« 

Example: 


EX  AF,  AF' 
Before: 


After: 


08 


aI 

04 

81 

V 

90 

3A.  ,1 

A 

90 

3A 

A'l. 

04 

OBJECT  CODE 
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EX  DE,  HL         Exchange  the  HL  and  DE  registers. 


Function: 


DE  - — -  HL 


Format: 


I     I    0    1    0    1     I  EB 


Description:  The  contents  of  the  register  pairs  DE  and  HL  are 

exchanged. 


Data  Flow: 


Tinnng: 


1  M  cycle;  4  T  states;  2  usee  @  2  MHz 


Addressing  Mode:  Implicit. 


Flags: 


5     2  H         P/V    N  C 


(no  effect). 


Example: 


EX    DE,  HL 


Before: 


After: 


A4E6 


9604 


Hl 


9604 


OBJECT  CODE 
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EX  (SP),  HL      Exchange  HL  with  top  of  stack. 


Function: 


(SP)  *-*-L;  (SP  +  1)  *  H 


Formal: 


!      I      i      0     0  0 


E3 


Description:  The  contents  of  the  L  register  are  exchanged  with 

the  contents  of  the  memory  location  addressed  by 
the  stack  pointer.  The  contents  of  the  H  register 
are  exchanged  with  the  contents  of  the  memory 
location  immediately  following  the  one  addressed 
by  the  stack  pointer. 


Data  Flow: 


Timing: 


5  M  cycles;  19  T  states;  9.5  usee  @  2  MHz 


Addressmg  Mode:  Indirect. 


Flags: 


SZ  H  FVVN  C 


(no  effect). 
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Example:  EX   (SP),  HL 

Before:  After 
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EX    (SP),  IX       Exchange  IX  with  top  of  stack. 


Function: 
Formal: 


Descriplion: 


Data  Flow: 


I      I      0  I 


0    I     byte  I:  DD 
byte  2:  E3 


The  contents  of  the  low  order  of  the  iX  register 
are  exchanged  with  the  contents  of  the  memory 
location  addressed  by  the  stack  pointer.  The  con- 
tents of  the  high  order  of  the  iX  register  are  ex- 
changed with  the  conlents  of  the  memory  location 
immediately  following  the  one  addressed  by  the 
stack  pointer. 


A 
B 
D 
H 


SP 


DATA 


Timing:  6  M  cycles;  23  T  states;  1 1.5  usee  @  2  MHz 

Addressing  Mode:  indirect. 


Flags: 


5      Z  H         P/V     N  C 


(no  effect). 
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Example: 


EX    (SP),  IX 


Before: 


After: 


5P" 


9234 


0402 


IX[ 

5P' 


01 6B 


0402 


DD 


E3 


0402 
0403 


6B 


01 


0402 
0403 


34 


92 


OBJECT  CODE 
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EX    (SP),  lY       Exchange  I Y  with  top  of  stack. 


Function: 
Format: 


(SP)  -*iY|ow;  (SP  +  n  -*iYhigh 


1    I    I    (    I    0  I  f      byte  1:  FD 

byte  2:  E3 


Description: 


Data  Flow: 


Timing: 


The  contents  of  the  low  order  of  the  lY  register 
are  exchanged  with  the  contents  of  the  memory 
iocation  addressed  by  the  slack  pointer.  The  con- 
tents of  the  high  order  of  the  iY  register  are  ex- 
changed with  the  contents  of  the  memory  location 
immediateiy  following  the  one  addressed  by  the 
stack  pointer. 


A 
B 

D 
H 

lYl 


DATA 


6  M  cycles;  23  T  stales;  11.5  usee  @  2  MHz 


Addressing  Mode:  Indirect 
Flags: 


SI  H  P/V    N  C 


(no  effect). 
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Example: 


EX    (SP),  lY 


Before: 


After: 


BF03 


6211 


SPf 


..4D90, 


62n 


FD 


E3 


6211 
6212 


90 


4D 


6211 
6212 


■03- 


•Bf 


OBJEa  CODE 
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EXX 


Exchange  alternate  registers. 


Function: 


BC  *-BC';  DE  '-DE'=  HL  ^UV 


Format: 


Description: 


Data  Flow: 


A 
B 
D 
H 


I    10    1     I    0    0    I  D9 


The  contents  of  the  general  purpose  registers  are 
exchanged  with  the  contents  of  the  corresponding 
ahernate  registers. 


Timing:  i  M  cycle;  4  T  states;  2  usee  @  2  MHz 

Addressing  Mode:  Implicit. 


Flags: 


Example: 


S     2  H         PA/   N  C 


Before: 


(no  effect). 


After: 


D9 


OBJECT 
CODE 


A 

04 

2B 

f 

A 

04 

2B 

F 

B 

39 

26 

C 

B 

oo 

C 

0 

5-1 

02 

E 

D 

DO 

E 

H 

F1 

00 

t 

H 

E3 

L 

A' 

3F 

2A 

f 

A' 

3F 

2A 

F' 

Bi 

8C 

00 

C 

B* 

39 

26 

C 

D' 

93 

DO 

V 

D' 

54 

02  : ,  ■ 

E' 

IF 

E3 

V 

HI 

DO   :  ,  ,: 

L" 
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HALT 


Halt  CPU. 


Fund  ion: 
Format: 

Description: 


CPU  suspended. 


76 


CPU  suspends  operation  and  executes  NOP's  so 
as  to  continue  memory  refresh  cycles,  until  in- 
terrupt or  reset  is  received. 


Timing: 


I  M  cycle;  4  T  states;  2  usee 
finite  Nop's. 


2  MHz  +  inde- 


Addressmg  Mode:  implicit. 


Flags: 


s  z 


H         P/V   N  C 


(no  effect). 
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IMO 


Set  interrupt  mode  0  condition. 


Function: 
Format: 


Internal  interrupt  control. 


i  0 


0   0   0    1    10      byte  2:  46 


byte  i:  ED 


Description: 


Timing: 


Sets  interrupt  mode  0.  In  this  condition,  the  in- 
terrupting device  may  insert  one  instruction  onto 
the  data  bus  for  execution,  the  first  byte  of  which 
must  occur  during  the  interrupt  aclcnowledge  cycle. 

2  M  cycle;  8  T  states;  4  usee  @  2  MHz 


Addressing  Mode:  Implicit 
Flags:  ^  z. 


H         P/V    N  C 


(no  effect). 
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IMl 


Set  interrupt  mode  1  condition. 


Function: 
Format: 


Description: 


Internal  interrupt  control. 


I    0    I     byte  J :  ED 


0    10    1(0    byte  2:  56 


Sets  interrupt  mode  1.  A  RST  003 8 H  instruction 
will  be  executed  when  an  interrupt  occurs. 


Data  Flow: 


00 


38 


(at  time  of  interrupt) 


003B 


iNT 


ROUTINE 


PCH 
PCI 


STACK 


Timing: 


2  M  cycles;  8  T  states;  4  usee  @  2  MHz 


Addressing  Mode:  Implicit. 


Flags: 


S     Z  H         P/V  N  C 


(no  effect). 
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IM2 


Set  interrupt  mode  2  condition. 


Function: 


Internal  interrupt  control. 


Formal: 


III 


byte  1:  ED 


0    I    0    !    (    i    s    0      byte  2;  5E 


Description: 


Timing: 


Set  interrupt  mode  2.  When  an  interrupt  occurs, 
one  byte  of  data  must  be  provided  by  the  peripheral 
which  IS  used  as  the  low  order  of  an  address.  The 
high  order  of  this  vector  address  is  taken  from  the 
contents  of  the  I  register.  This  points  to  a  second 
address  stored  in  memory, which  is  loaded  into  the 
program  counter  and  begins  execution. 

2  M  cycles;  8  T  states;  4  usee  @  2  MHz 


Addressing  Mode:  Implicit. 
Flags:  SI       h      pa/  n  c 


(no  effect) 


260 


THE  Z80  INSTRUCTION  SET 


IN  r,  (C) 


Load  register  r  from  port(C) 


Fund  ion: 
Forniai: 


r  -{Q 


i 

i 

0 

i 

byle  1 :  ED 

I  0 

1 

1  1 

1  I 

0 

0 

0 

byte  2 

Descnplion: 


Data  Flow. 


The  peripheral  device  addressed  by  the  contents  of 
the  C  register  is  read  and  the  result  is  loaded  into 
the  specified  register. 

C  provides  bits  AO  to  A7  of  the  address  bus. 
B  provides  bits  A8  to  A15. 


1^ 


r  may  be  any  one  of: 


A  -  111 

B  -  000 

C  -  001 

D  -  010 


E  -  Oil 
H  -  100 
L  -  101 


PORT 


Timing:  3  IVl  cycles;  12  T  states;  6  usee  @  2  MHz 

Addressing  Mode:  External. 
Bvte  Codes: 


r:     A     B     C     D     E  HI. 

ED  I  76 

-SO 

4S 

50 

58 

60 

68 
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Flags: 


s  z 


N  C 


o 


It  is  important  to  note  that  INA,(N)  does  not  have 
any  effect  on  the  flags,  while  IN  r,  (C)  does. 


Example: 


IN    D,  (C) 


Before: 


After: 


£D 


50 


09 


OBJECT  CODE 


A5        I  ( 


6A 


A5 


I  PORT  °»J3 


A5 


6A 


AS 


PORT 
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IN   A,  (N)  Load  accumuiator  from  input  port  N. 


Function: 


A  -  (N) 


Formal: 


I 

1 

0 

1 

1 

0 

1 

1 

J  L 


J  !  L 


byte  I:  DB 

byte  2:  port  address 


Descnplion:  The  peripheral  device  N.  is  read  and  the  result  is 

loaded  into  the  accumulator. 
The  literal  N  is  placed  on  lines  AO  to  A7  of  the 
address  bus.  A  supplies  bits  A8  to  A15. 


Data  Flow: 


A 

WmWm 

B 

c 

D 

E 

H 

L 

POST 

IN 


Timing:  3  tvl  cycles;  11  T  states;  5.5  usee  @  2  MHz 

Addressing  Mode:  External. 

Flags: 


5    z  H       p/v  N  c 


Example: 


IN    A,  (B2) 


(no  effect). 


Before: 


After: 


DB 


B2 


S4 


B2 


OBJECT  CODE 


POST  A^FIJ 


Fl  FORT 


B2 
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INC  r 

Function: 
Format: 

Description: 


Data  Flow: 


Increment  register . 
r     r  +  1 


The  contents  of  the  specified  register  are  in- 
cremented, r  may  be  any  one  of: 


A  -  111 
B  -  000 
C  -  001 
D  -  010 


E  -  on 

H  -  100 
L  -  101 


Timing:  I  M  cycle;  4  T  states;  2  usee  @  2  MHz 

Addressing  Mode:  Implicit. 
Byte  Codes: 


Flags: 
Example: 


r; 

A 

B 

C 

D 

E 

H 

L 

3C 

O'i 

00 

)4 

IC 

24 

2C 

INC  D 
Before: 


06 


s 

z 

H 

P/® 

C 

# 

® 

® 

• 

o 

After: 


D  W^PW/M 
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INC   rr  Increment  register  pair  rr. 


Function:  rr  rr  +  1 
Format:   


0 

0 

! 
r 

\ 

0 

0 

i 

1 

Description:  The  contents  of  the  specified  register  pair  are  in- 

cremented and  the  result  is  stored  back  in  the 
register  pair,  rr  may  be  any  one  of: 

BC  -  00  HL  -  10 

DE  -  01  SP  -  11 


Timing:  i  M  cycle;  6  T  states;  3  usee  @  2  MHz 

Addressing  Mode:  Implicit. 


Byte  Codes:  rr: 


BC 

DE 

HL 

SP 

03 

13 

23 

33 
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Flags: 


S      Z  H         PA'    N  C 


(no  effect). 


Example:  INC  HL 


Before: 


After; 


23 


H  0B14 


]l      h|.  ;../;  ■'■/  obis: 


OBJECT 
CODE 
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INC  (HL) 

Funciion: 
Format: 

Description: 


Data  Flow: 

B  ~ 
H  "~ 


Timing: 


Increment  indirectly  addressed  memory  location 
(HL). 

(HL)  *-  (HL)  +  i 


0    0!    i    0    i    0    0  34 


The  contents  of  the  memory  location  addressed  by 
the  HL  register  pair  are  incremented  and  stored 
back  at  that  location. 


3  M  cycles;  11  T  states;  5.5  usee  @  2  MHz 


Addressing  Mode:  Indirect. 
Flags: 


s 

1 

H 

P/gS  N 

9 

9 

• 

9 

O 

Example:  INC  (HL) 

Before: 


After: 


06B1 


0681 


34 


06BI 


3B 
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INC  (IX  +  d)     increment  indexed  addressed  memory  location 
(IX  +  d). 


Function: 
Format: 


(IX  +  d)  *-  (IX  +  d)  +  1 


1  1  1 

0  1  1 

1 

!  1  0 

0 

0 

1 

i 

0 

j 

0 

0 

-T  1  1  T  1  !  r' 

 d  

 I  I  u~  L,„,„^  


byte  1 :  DD 

byte  2:  34 

byte  3:  offset  value 


Description:  The  contents  of  the  memory  location  addressed  by 

the  contents  of  the  IX  register  plus  the  given  offset 
value  are  incremented  and  stored  back  at  that 
location. 


Timing:  6  M  cycles;  23  T  states;  !  1 .5  usee  @  2  MHz 


Addressing  Mode:  indexed. 


Flags: 


P/®  N  C 


m 

m 

0 

268 


Example: 


OBJECT 
CODE 


THE  Z80  INSTRUCTION  SET 

INC    (IX  +  2) 

Before:  After: 

iX|  03BI  ~|  SX|   03B1  ~ 


03B1 
03B2 
0383 


Bl 


65 


B9 
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INC  (lY  +  d)     Increment  indexed  addressed  memory  location  (lY 
+  d). 


Function: 
Format: 


(lY  +d)  *-  (lY  +  d)  +  1 


i  i 


0 

0 

1 

\ 

0 

\ 

0 

0 

-d  ■ 


_l  !  i  !  i  I  1_ 


byte  J :  FD 

byte  2:  34 

byte  3:  offset  value 


Description: 


Data  Flow: 
a[" 

B 
D 
H 


lY 


TJie  contents  of  the  memory  location  addressed  by 
the  contents  of  the  lY  register  plus  the  given  offset 
value  are  incremented  and  stored  back  at  that 
location. 


Timing:  6  M  cycles;  23  T  states;  11.5  usee  @  2  MHz 

Addressing  Mode:  Indexed. 


Flags: 


5 

Z 

H 

N 

c 

• 

• 

• 

• 

0 
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Example: 


INC    (lY  +0) 


Before: 

!yI  0601 


After: 


0601 


34 


00 


OBJECT 
CODE 


0601 
0602 


BO 


0601 
0602 


BO 
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INC  IX 


Increment  IX. 


Function: 
Format: 


IX     IX  +  J 


Descriplton: 


Data  Flow: 


I      I      0      I      I  10 


0     0     i     0     0     0     I  I 


byte  1;  DD 


byte  2:  23 


The  contents  of  the  IX  register  are  incremented 
and  the  result  is  stored  back  in  IX. 


Timing:  2  M  cycles;  10  T  states;  5  usee  @  2  MHz 

Addressing  Mode:  Implicit. 
Flags:  s    z        h       p/v  n  c 


(no  effect). 


Example: 


INC  IX 
Before: 


DD 


23 


B160 


OBJECT  CODE 


After; 
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INC  lY 

Function: 
Format: 


Description: 


Data  Flow: 


Increment  lY 
lY     lY  +  1 


I     I     !     !     =    I    0    s   byte  1 :  FD 

byte  2:  23 


0 

0 

1 

0 

0 

0 

1 

1 

The  contents  of  the  lY  register  are  incremented 
and  the  result  is  stored  back  in  lY. 


Timing:  2  M  cycles;  10  T  states;  5  usee  @  2  MHz 

Addressing  Mode:  Implicit. 


Flags: 


5    z         H       p/v   N  c 


(no  effect). 


Example: 


FD 


23 


OBJECT  CODE 


INC  lY 

Before: 


36B1 


After: 
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IND 

Function: 
Format: 


Description: 


Data  Flow: 


Timing: 


Input  With  decrement. 

(HL)  *-  (C);  B     B  -  i;  HL 


HL 


( 

) 

i 

0 

i 

i 

0 

1 

byte  1 :  ED 
byte  2:  AA 

1 

0 

1 

0 

1 

0 

1 

0 

The  peripheral  device  addressed  by  the  C  register 
is  read  and  the  result  is  loaded  into  the  memory 
location  addressed  by  the  HL  register  pair.  The  B 
register  and  the  HL  register  pair  are  then  each 
decremented. 


4  M  cycles;  16  T  states;  8  usee  @  2  MHz 


Addressmg  Mode:  External. 
Flags: 


_s  z 


H         PA'  N  C 


Set  if  B  =  0  after  execution 
Reset  otherwise 
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Example: 


IND 


Before; 


After: 


B  Al 


B5 


B5 


06BA 


26  PORT 


85 


36  TORT 


B5 


ED 


AA 


OBJECT  CODE 


06BA 


00 


06BA 
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INDR 

Function: 

Format: 


Block  input  with  decrement. 

(HL)  *-  (C);  B  B  -  1;  HL  -  HL  -  1 
Repeat  until  B  =  0 


— 1  


byte  I:  ED 
byte  2:  BA 


Description:  The  peripheral  device  addressed  by  the  C  register 

is  read  and  the  result  is  loaded  into  the  memory 
location  addressed  by  the  HL  register  pair.  Then 
the  B  register  and  the  HL  register  pair  are 
decremented.  If  B  is  not  zero,  the  program 
counter  is  decremented  by  2  and  the  instruction  is 
re-executed. 


Data  Flow, 


Timing: 


B  =  0:4  M  cycles;  16  T  states;  8  usee  @  2  MHz. 
B     0:5  M  cycles;  21  T  states:  10.5  usee  @  2  MHz. 


Addressing  Mode:  External 


Flags: 


f  I  I 
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Example: 


INDR 


Before: 


After: 


03 


09F2 


56 


86 


56 


Iport 


BF 


c 

Iport 


ED 


BA 


OBJECT  CODE 


09EF 

6A 

09F0 

EB 

09F1 

40 

09F2 

9A 

09EF 
09F0 
09FI 
09F2 


6A 


1^ 
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INI 


Input  with  increment. 


Function: 


(HL)  -  (C);  B  -  B  -  1;  HL     HL  +  1 


Formal: 


0      I      i      0  I 


byte  i:  ED 


1 

0 

1 

0 

0 

0  I  1 

0 

0   byte  2:  A2 


Description:  The  peripheral  device  addressed  by  the  C  register 

IS  read  and  the  result  is  loaded  into  the  memory 
location  addressed  by  the  HL  register  pair.  The  B 
register  is  decremented  and  the  HL  register  pair  is 
incremented. 

The  contents  of  C  are  placed  on  the  low  half  of  the 
address  bus.  The  contents  of  B  are  placed  on  the 
high  half.  I/O  selection  is  generally  made  by  C, 
i.e.,  by  AO  to  A7.  B  is  a  byte  counter. 


Data  Flow: 


.  ' ,.  .. 

PORT 


DATA 


Timittg: 


4  M  cycles;  16  T  states;  8  usee  @  2  MHz 


Addressing  Mode:  External. 
Flags: 


s  z 


P/V  N  C 


1 


Z  is  set  if  B  =  0  after  execution, 
Reset  otherwise 
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Example:  INI 
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INIR  Block  input  with  increment. 


Function: 


(HLi  *-  (C);  B  B  -  U  HL  HL  +  I;  Repeat 
until  B  =  0 


Formal: 


■ 

{ 

0 

1 

1 

0 

1 

,  u 

1 

1 

0 

0 

i 

0 

byie  !;  ED 


Descnplion:  The  peripheral  device  addressed  by  the  C  register 

IS  read  and  the  result  is  loaded  into  the  memory 
location  addressed  by  ihe  HL  register  pair.  The  B 
register  is  decremented  and  the  HL  register  pair  is 
incremented.  !f  B  is  not  zero,  the  program  counter 
IS  decremented  by  2  and  the  instruction  is  re- 
executed. 


Daia  Flow: 


Timing: 


B  =  0:  4  M  cycles;  16  T  slates;  8  used  @  2  MHz. 
B  #  0:  5  M  cycles;  21  T  stales;  10,5  usee  @  2  MHz. 


Addressing  Mode:  External. 


Flags: 


p/v  H 
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Example:  INIR 


Before:  A  tier: 


h|         91A5         li  hWWMWM'MMM^ 


PORT 
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JP  CC,  pq 


Jump  on  condition  to  location  pq. 


Function: 
Formal: 


if  cc  true;  PC  pq 


T — r 


1 — r 


byte  I 

byte  2:  address, 
low  order 

byte  3:  address, 
high  order 


Description:  If  the  specified  condition  is  true,  the  two-byte  ad- 

dress immediately  following  the  opcode  wiii  be 
loaded  into  the  program  counter  with  the  first  byte 
following  the  opcode  being  loaded  into  the  low 
order  of  the  PC.  If  the  condition  is  not  met,  the 
address  is   ignored,  cc  may  be  any  one  of: 


NZ  - 

000 

no  zero 

Z  - 

001 

zero 

NC  - 

010 

no  carry 

C  - 

01! 

carry 

PO  - 

100 

parity  odd 

PE  - 

101 

parity  even 

p  ^ 

no 

plus 

M  - 

ill 

minus 

Data  Flo  w. 
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Timing: 


THE  280  INSTRUCTION  SET 
3  IVI  cycles;  10  T  stales;  5  usee  @  2  MHz 


Addressing  Mode:  immediate 
Byte  Codes: 


Flags: 


c  c 

NZ 

Z 

NC 

C 

PO 

P£ 

P 

M 

C2 

CA 

D2 

OA 

£2 

EA 

F2 

s  z 

H 

P/V  N 

C 

(no  effect) 


Example: 


JP    C, 3B24 


OA 


21 


3B 


OBJECT  COOE 


Before: 


After: 


51 


PC 


0032 


PC 


^^^^^^^^^^^^^^^^ 
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JP  pq 

Function: 
Format: 


Description: 


Data  Flow: 


Jump  to  location  pq. 


PC 

pq 

1 

0 

0 

0 

0 

1 

1 

byte  i:  C3  f1  S 

byte  2:  address. 

^      t      i      f      1      1      1  ' 

 q  

low  order 

byte  3:  address, 
high  order 


The  contents  of  the  memory  location  immediately 
following  the  opcode  are  loaded  into  the  low  order 
half  of  the  program  counter  and  the  contents  of 
the  second  memory  location  immediately  foilow- 
mg  the  opcode  are  loaded  into  the  high  order  of 
the  program  counter.  The  next  instruction  will  be 
fetched  from  this  new  address. 


Timing:  3  M  cycles;  10  T  states;  5  usee  @  2  MHz 

Addressing  Mode:  Immediate. 

S     Z  H  P/V   N  C 


Flags: 
Example. 


]  (No  effect) 


JP  3025 
Before: 


After: 


C3 


25 


30 


PC 


5520 


OBJECT  CODE 
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JP  (HL) 

Fiincltoti: 
Formal: 

Descnpiiofi: 
Data  Flow: 


Jump  to  HL. 
PC  -  HL 


1 

I 

i 

0 

'  1  ° 

0 

1 

'  1 

The  conienis  of  ihe  HL  regisler  pair  are  loaded  in- 
lo  ihe  program  counier.  The  nexl  in.slruciion  is 
I'eiched  from  this  new  address. 


Tiiiii/ig: 


i  M  cycle;  4  T  siaies;  2  usee  @  2  MHz 


Addressing  Mode:  Implicit 
Flags: 


Example: 


OBJECT  CODE 


S     Z  H  P/V   N  C 


JP  (HL) 
Before: 


PC 


BOOl 


(no  effect). 


After; 


L  H 


041  I 
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JP  (IX) 

Function: 
Format: 

Description: 
Data  Flow: 


Jump  10  IX. 
PC  *-  IX 


! 

1 

0    j  1 

byte  1;  DD 

1 

1 

t 

0 

1 

0 

0 

1 

byte  2:  E9 

The  contents  of  the  iX  register  are  loaded  into  the 
program  counter.  The  next  instruction  is  fetched 
from  this  new  address. 


Timing:  1  M  cycles;  8  T  states;  4  usee  @  2  MHz 

Addressing  Mode:  Implicit. 

5     z  H        P/V    N  c 


Flags: 
Example: 


JP  (IX) 
Before: 


1X1 

PC  I 


80F1 


3B4A 


(no  effect). 


After; 


IX  j 
PC^ 


OBJECT  CODE 


286 
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JP  (lY) 

Funaion: 

Fomuii: 


Description: 


Duia  Flow: 


Jump  lo  !Y- 
PC  -  lY 


0  0 


byte  !:  FD 
]      byie  2:  E9 


Tile  eonfcnt.s  of  ihc  (Y  register  are  moved  inio  ilie 
program  courner.  The  nexi  inslruclion  will  be  fei- 
ched  from  this  new  address. 


Timing:  2  M  cycles;  8  T  stales;  4  usee  @  2  MHz 

Addressing  Mode:  Implicit. 

5     2  H  P/y    N  C 

(no  effect). 


Flags: 


Example: 


JP  (lY) 

Before: 


After: 


FD 


E9 


OBJECT  CODE 


pel 


£410 


iV 


AA4B 
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JR  cc,  e 


Jump  e  relative  on  condition. 


Function: 


Formal: 


Description: 


Data  Flow. 

A 
B 

D 
H 


if  CC  true.  PC     PC  +  e 


0 

0 

i 

c 

0 

0 

0 

 —  2- 

J  I  L— 


byte  1 

byte  2:  offset  value 


If  the  specified  condition  is  met,  the  given  offset 
value  is  added  to  the  program  counter  usmg  two's 
comptement  arithmetic  so  as  to  enable  both  for- 
ward and  backward  jumps.  The  offset  value  is 
added  to  the  value  of  PC  +  2  (after  the  jump).  As 
a  result,  the  effective  offset  is  -126  to  +129  bytes. 
The  assembler  automatically  subtracts  2  from  the 
source  offset  value  to  generate  the  hex  code.  If  the 
condition  is  not  met,  the  offset  value  is  ignored 
and  instruction  execution  continues  in  sequence, 
cc  may  anyone  of: 

NZ  -  00  NC  -  10 


01 


11 


JR 


e-2 


Timing: 


M  cycles: 

T  stales: 

usee 
@  2  MHz: 

condition 
met: 

3 

12 

6 

condition 
not  met; 

7 

3.5 
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Addressing  Mode:  Relative. 


Byle  Codes:  cc: 


NZ 

Z 

NC 

C 

20 

28 

30 

33 

Flags:  s    z        h       p/v  n  c 

 ill  (no  effect). 

Example:  JR    NC,  $  -  3  S  =  current  PC 

Before:  After: 


GO      \f  I      00  If 


OBJECT  CODE 
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Me 

Function: 
Format: 


Jump  e  relative. 
PC     PC  +  e 


0 

0 

o|, 

1 

0 

0  1  0 

— I — 
-e-2  - 


0     byte  i:  18 

byte  2:  offset  value 


Description: 


The  given  offset  value  is  added  to  the  program 
counter  using  two's  complement  arithmetic  so  as  to 
enable  both  forward  and  backward  jumps.  The  off- 
set value  is  added  to  the  value  of  PC  +  2  (after  the 
jump).  As  a  result,  the  effective  offset  is  -126  to 
-1-  129  bytes.  The  assembler  automatically  subtracts 
2  from  the  source  offset  value  to  generate  the  hex 
code. 


Data  Flow: 


Addressing  Mode:  Relative. 
Flags:  5    z  _h   p/y_j± 


(no  effect) 


Example: 


JR  D4 
Before: 


16 


D2 


PC 


BlOO 


After: 


(This  is  a  backwards  jump.) 


OBJECT  CODE 
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LD  dd,  (nn) 

Function: 


Load  register  pair  dd  from  memory  iocations  ad- 
dressed by  nn. 


ddlow  *-  (nn);  ddhigh  *~  (nn  +  J ) 


Formal: 


Descnpiion: 


0      1      0  0 


I    0    I    byte  1:  ED 


d  d 


i  0 


i  h  I  byte  2 


-1  \ 


!  I  i  [_ 


byte  3:  address, 
low  order 

byte  4:  address, 
tiigh  order 


The  contents  of  the  memory  location  addressed  by 
the  memory  locations  immediately  followmg  the 
opcode  are  loaded  into  the  iow  order  of  the 
specified  register  pair.  The  contents  of  the 
memory  location  immediately  following  the  one 
previously  loaded  are  then  loaded  into  the 
high  order  of  the  register  pair.  The  iow  order  byte 
of  the  nn  address  immediately  follows  the  opcode, 
dd  may  be  any  one  of; 


BC  -  00 
DE  -  01 


HL 
SP 


10 

11 
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Timing:  6  M  cycles;  20  T  states;  10  usee  @  2  MHz 

Addressing  Mode:  Direct. 


to- 


BC 

DE 

HL 

SP 

AB 

5B 

SB 

7B 

Flags: 


5     Z  H  P/V    N  C 


(no  effect) 


Example: 


LD   DE.  (5021) 


OBJEa  CODE 


Before: 


After: 


ED 


21 


50 


5021 
5022 


30 


5021 
5022 


30 
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LD  dd,  nn 

Function: 

Format: 


Description: 


Load  register  pair  dd  with  immediate  data  nn. 
dd  *-  nn 


0     0  d 


~\ — r 


J  L 


"i — r 


J  i  L 


byte  2:  immediate 
data,  low  order 

byte  3:  immediate 
data,  high  order 


The  contents  of  the  two  memory  locations  im- 
mediately following  the  opcode  are  loaded  mto  the 
specified  register  pair.  The  lower  order  byte  of  the 
data  occurs  immediately  after  the  opcode,  dd  may 
be  any  one  of; 


BC  -  00 
DE  -  01 


HL  -  10 
SP  -  11 


Data  Flow: 


LD 

!  

n 

n 

Timing: 


3  M  cycles;  10  T  states;  5  usee  @  2  MHz 


Addressing  Mode:  Immediate 
Byte  Codes: 


sc 

oe 

HL 

SP 

01 

11 

21 

31 

Flags: 


PA'  N  c 


(no  effect) 
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Example:  LD    DE.  4131 


Before: 


0394 


OBJECT  CODE 


294 


LDr,  n 


THE  Z80  INSTRUCTION  SET 
Load  register  r  with  immediate  data  n. 


Function: 
Format: 


byte  i 

byte  2:  immediate  data 


Description:  The  contents  of  the  memory  location  immediately 

foilowing  the  opcode  location  are  loaded  into  the 
specified  register,  r  may  be  any  one  of: 


A  -  111 
B  -  000 
C  -  001 
D  -  010 


E  -  Oil 
H  -  100 
L  -  101 


Data  Flow: 


1 

LD 

Timing:  2  M  cycles;  7  T  states;  3.5  usee  @  2  MHz 

Addressing  Mode:  Immediate. 


Byte  Codes: 


r:  A    a   c   o    E    H  L 


3E 

06 

OH 

16 

1£ 

26 

21 

Flags: 


5     Z  H  P/V   N  C 


(no  effect). 
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Example: 


LD  C,  3B 
Before; 


OE 


3B 


01 


After: 


OBJECT  CODE 
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LD  r,  r 


THE  Z80  INSTRUCTION  SET 
Load  register  r  from  register  r'. 


Function: 
Format: 

Description: 


r  *- 

r' 

0 

1 

■    1  s 
1  1 

 1  ^  t 

1  1 

The  contents  of  the  specified  source  register  are 
loaded  into  the  specified  destination  register,  r  and 
r'  may  be  any  one  of: 


A  -  HI 
B  -  000 
C  -  001 
D  -  010 


E  -  Oil 
H  -  100 
L  -  101 


Data  Flow: 


Timing:  i  M  cycle;  4  T  states;  2  usee  @  2  MHz 

Addressmg  Mode:  Implicit. 


Byte  Codes: 


A    B    C     0    E  H 


(source) 


A 
B 
C 
0 
E 
H 
L 

(dest. ) 


7F 

78 

79 

7A 

7S 

7C 

7D 

47 

40 

4! 

42 

43 

44 

45 

4F 

48 

49 

4A 

4B 

4C 

4D 

57 

50 

51 

52 

53 

54 

55 

5F 

58 

59 

5A 

5B 

SC 

5D 

67 

60 

b\ 

62 

63 

bA 

65 

6F 

68 

69 

6A 

6B 

6C 

6D 

Flags: 


P/V  N 


(no  effect). 
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Example:  LD    H,  A 

Before:  After: 


OBJECT  CODE 


298 
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LD  (BC),  A         Load  indirectly  addressed  memory  location  (BC) 
from  the  accumulator. 


Function: 
Format: 


(BO  *-  A 


r — I  i  1  1 — T — 

I  0  [  0     0     0  f  0  I  0 


02 


Description:  The  contents  of  the  accumulator  are  loaded  into 

the  memory  location  addressed  by  the  contents  of 
the  BC  register  pair. 


Data  Flow: 


DATA 


Timing:  1  M  cycles;  7  T  stales;  3.5  usee  @  2  MHz 

Addressing  Mode:  Indirect. 
Flags: 


Example: 


5     z  H  P/V  N  c 

[XlJ„:iJZi:n    (no  effect). 


LD  (BC),  A 
Before: 


After: 


3F 


4109 


A  3F 
B 


4109 


02 


4109 


OBJECT  CODE 
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LD  (DE),  A        Load  indirectly  addressed  memory  location  (DE) 
from  the  accumulator. 


Function: 
Format: 

Description: 
Data  Flow: 


(DE)  *-  A 


0 

0 

0 

! 

0 

0 

{ 

0 

The  contents  of  the  accumulator  are  loaded  into 
the  memory  location  addressed  by  the  contents  of 
the  DE  register  pair. 


Timing:  2  M  cycles;  7  T  states;  3,5  usee  @  2  MHz 

Addressing  Mode:  Indirect. 
Flags: 


5     Z  H         P/V  N  c 


(no  effect) 


Example: 


LD  (DE),  A 
Before; 


A 

D  ' 


ED 


After: 


ED 


0392 


E  D 


0392 
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LD  (HL),  n  Load  immediate  data  n  into  the  indirectly  ad- 

dressed memory  location  (HL). 


Function: 
Format: 


(HL)  *-  n 


byte  2:  immediate 
data 


Description:  The  contents  of  the  memory  location  immediately 

following  the  opcode  are  loaded  into  the  memory 
location  indirectly  addressed  by  the  HL  data 
pointer 


Data  Flo  w: 


Timing: 


3  M  cycles;  10  T  states;  5  usee  @  2  MHz 


Addressing  Mode:  Immediate/indirect. 


Flags: 


S      Z  »  P/V    H  C 


(no  effect). 
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Example: 


LD    (HL),  5A 


Before: 


After: 


A3-12 


jl        h|  A342  ji 


36 


5A 


OBJECT  CODE 


A342 


2D 


A342 
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LD  (HL),  r  Load  indirectly  addressed  memory  location  (HL) 

from  register  r. 


Function: 


(HL)  -  r 


Format: 


Description:  The  contenls  of  the  specified  register  are  loaded 

into  the  memory  location  addressed  by  the  HL 
register  pair,  r  may  be  any  one  of: 


A  -  ill 

B  -  000 

C  -  001 

D  -  010 


E  - 
H  - 

L  - 


Oil 
100 
101 


Data  Flo  w: 


DATA 

m. 

Timing: 


2  M  cycles;  7  T  states;  3.5  usee  @  2  MHz 


Addressing  Mode:  Indirect 
Byte  Codes: 


A     B     C     D     E      H  L 


77 

70 

71 

72 

73 

7A 

75 
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Flags:  s    z        h       pa^     ,  ^  , 

(no  effect). 

Example:  LD    (HL),  B 


Before: 


After; 


B  81 


OSJEa  CODE 


304 
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LD  r,  (IX  +  d)     Load  register  r  indirect  from  indexed  memory 
iocation  (IX  +  d) 


Function: 
Format: 


{IX  +  d) 


-T  r- 

d   


byte  J:  DD 
byte  2 

byte  3:  offset  value 


Description:  The  contents  of  the  memory  location  addressed  by 

the  IX  index  register  pius  the  given  offset  value, 
are  loaded  mto  the  specified  register,  r  may  be  any 
one  of; 


A  -  11! 
B  -  000 
C  -  001 
D  -  010 


E  -  Oil 
H  ™  100 
L  -  101 


Data  Flo  w: 


A 
S 
D 
H 


:  ) 


LD 


Timing: 


5  M  cycles;  19  T  states;  9.5  usee  @  2  MHz 


Addressing  Mode:  Indexed 
Byte  Codes: 


A 

B 

C 

D 

E 

H 

L 

7E 

Ai, 

4E 

S6 

5E 

66 

6E 

-d 
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Flags: 


5     1  H         P/V  N  c 


(no  effect). 


Example: 


LD    E,  (IX  +  5) 


Before: 


After: 


!       03  jE 
IX I  3020  1      IX I  3020 


DO 


5E 


OS 


OBJECT  CODE 


3020 


3025 


2A 


IS 


3020 


3025 


2A 


15 
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LD  r,  (iY  +  d)     Load  register  r  indirect  from  indexed  memory 
location  (IY  +  d) 


Function: 


r  —  (IY  +  d> 


Format: 


1 

1 

i 

) 

0 

i 

byte  1 :  FD 

0 

i 

 1  \  

'  1 

1 

! 

0 

byte  2 

byte  3:  offset  value 


Description:  The  contents  of  the  memory  location  addressed  by 

the  IY  index  register  plus  the  given  offset  value, 
are  loaded  into  the  specified  register,  r  may  be  any 
one  of: 


A  -  111 
B  ~  000 
C  -  001 
D  -  010 


E  -  Oil 
H  -  too 
L  -  101 


Data  Flow: 


DATA 


) 

d 

Timing: 


5  M  cycles,  19  T  states;  9.5  usee  @  2  MHz 


Addressing  Mode:  Indexed. 
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Byte  Codes: 


A 

B 

C 

D 

E 

H 

L 

7E 

46 

4E 

56 

56 

66 

6E 

-  d 

Flags: 


5     Z  H  P/V  N  C 


(no  effect). 


Example: 


LD   A,  (lY  +  2) 


Before: 


E3 


BOOS 


After: 


BOOS 


FD 


76 


02 


OBJECT  CODE 


BOOS 


B007 


61 


F9 


BOOS 


B0G7 


f9 
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LD  (IX  +  d),  n    Load  indexed  addressed  memory  location  {IX  + 
d)  With  immediate  data  n. 


Function: 
Format: 


Description: 


Data  Flow: 


{IX  +  d)  *-  n 


1 

i 

0 

i 

1  [  1 

0 

i 

0 

0 

1 

1 

0 

1 

1 

0 

-1  1  1  1  1  r 


_i  1  ^  1  ^ 


_j  I  1  I  I  L_ 


byte  3:  offset  vaiue 

byte  4:  immediate 
data 


The  contents  of  the  memory  location  immediately 
following  the  offset  are  transferred  into  the 
memory  location  addressed  by  the  contents  of  the 
index  register  plus  the  given  offset  value. 


a: 
B 
D 
H 


Timing:  5  M  cycles;  19  T  states;  9.5  usee  @  2  MHz 

Addressing  Mode:  Indexed/immediate. 


Flags: 


SI  H  P/V  N  C 


(no  effect). 
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Example: 


LD   (IX  +  4),  FF 


m 


Before: 


After: 


DD 

B109 

BI09 

36 

04 

Ff 

BIOD 

4E 

BIOD 

THEZ80  INSTRUCTION  SET 


IJ10¥  +  Load  indexed  addressed  memory  tocaUon  (lY  + 

d)  with  immediale  data  n . 


Function: 
Fsmmt 


Description: 


DemFlow: 


(lY  +  d)  n 


1 

1 

1 

1 

1 

1 

0 

1 

0 

0 

1 

1 

0 

1 

1 

'  1° 

I  I  I  d-Lzr 


1    I  I 


J  I  L 


J  I  I 


byte  1:  FD 
byte  i:  M 

byte  3:  offset  value 

byte  4:  inamediate 
data 


The  contents  of  the  memory  location  immediately 
Mtwfog  t^F^  mti  ^ansferred  into  the  me- 
mory location  addressed  by  the  contents  of  the 
index  register  plus  the  given  offset  value. 


ID 

d 

n 

Tttmtg: 


5  M  cydes;  19  T  states;  9,5  usee  @  2  MHz 


Mode:  Indexed/immediate, 

i 

S     Z  H         P/V    N  C 


i(no  effect). 
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Example:  LD   (lY  +  3),  BA 

Before:  After: 

lY  f  0100  ~]        !Y  I 


OBJECT  CODE 
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LD  (IX  +  d),r      Load  indexed  addressed  memory  location  (IX  + 
d)  from  register  r. 


Function: 


(IX  +  d)-* — r 


Format: 


1 

1 

0 

! 

1 

1 

0  j  1 

0 

1 

s 

! 

0 

 1 ! 

i  '  5 

byte  1:DD 
byte  2 

byte  3:  offset  vaiue 


Description:  The  contents  of  specified  register  are  loaded  into 

tlie  memory  location  addressed  by  the  contents  of 
the  index  register  plus  the  given  offset  value,  r  may 
beany  one  of: 


A  -  111 
B  -  000 
C  -  001 
D  -  010 


E  -  on 

H  -  100 
L  -  101 


Data  Flow: 


A 
B 
D 
H 

IX  I 


DATA 


LD 

d 

Timing: 


5  M  cycles;  19  T  states;  9.5  usee  @  2  MHz 
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Addressing  Mode:  Indexed. 


Flags: 


Byte  Codes: 

r: 

A 

B 

C 

D 

i 

H 

L 

DD- 

77 

70 

71 

72 

73 

74 

75 

S     Z  H         P/V  N  C 


(no  effect). 


Example: 


LD    (IX  +  1),  C 

Before:  After: 


6B 


IX 


4462 


4B 


IX 


4462 


DD 


01 


OBJECT  CODE 


4462 
4463 


9D 
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LD  (lY  +  d),  r     Load  indexed  addressed  memory  location  (lY  + 
d)  from  register  r. 


Fimciion: 
Forma!: 


(lY  +  d)  r 


i 

1 

1 

1 

1 

1      0  1 

0 

1 

i 

1 

0 

— 

1  \  1  1  !  1  1  1  

 6  

 1  .  1 

byle  !:  FD 
byte  2 

byte  3:  offset  value 


Descnptton: 


Data  Flow: 


The  contents  of  the  specified  register  are  loaded 
into  the  memory  location  addressed  by  the  con- 
tents of  the  index  register  plus  the  given  offset 
value,  r  may  be  any  one  of: 


A  -  HI 
B  -  000 
C  -  OOi 
D  -  QIC 


E  -  Oil 
H  -  too 
L  -  101 


A 

e 

D 
H 

IY| 


Timing:                 5  M  cycles;  19  T  states;  9.5  usee  @  2  MHz 
Addressing  Mode:  Indexed. 
Byte  Codes:         f:   a   b    c   d   e    h  l  


77 

70 

71 

72 

73 

74 

75 
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Flags:  s    z        h       pa/  n  c 

(no  effect). 

Example:  LD   (lY  +  3),  A 

Before:  After: 
A|       3E     ~]  Aj       3£  ~] 

SyI  5AB4  I         1y|  5AB4 


FD 
77 


03 


5A64 


SAB7 


21 


5A 


5AB4 


5AB7  ^^3E| 


OSJEa  CODE 
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LD  A,  (nil)  Load  accumulator  from  the  memory  location 

(nn). 


Function: 
Format: 


A  (nn) 


0 

0 

i 

i 

i 

0 

i 

0  j 

1  1  !  f— 

 n  ■ 

_l  1  !  L_ 


byte  1:  3  A 

byte  2:  address,  low 
order  byte 
n   byte  3:  address,  high 
— ^  order  byte 


Description:  The  contents  of  the  memory  location  addressed  by 

the  contents  of  the  2  memory  locations  immediate- 
ly following  the  opcode  are  loaded  mto  the  ac- 
cumulator. The  low  byte  of  the  address  occurs  im- 
mediately after  the  opcode. 


Data  Flow: 


A 

^^^^^^ 

B 

0 

H 

DATA 


LD 


Timing:  4  M  cycles;  13  T  states;  5.5  usee  @  2  MHz 

Addressing  Mode:  Direct. 
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Flags: 


S      Z  H  P/V  N  c 


(no  effect). 


Example: 


LD    A,  (3301) 


OBJECT  CODE 


Before: 


After: 


A  OA 


3A 


01 


33 


3301 


2B 


330) 


2B 
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LD  (nn),A         Load  directly  addressed  memory  location  (nn) 
from  accumulator. 


Function: 


(nn)  *-  A 


Format: 


J  L 


"1 — r 


byte  1:  32 

byte  2:  address,  low 
order 

byte  3:  address,  high 
order 


Descnption:  The  contents  of  the  accumulator  are  loaded  into 

the  memory  location  addressed  by  the  contents  of 
the  memory  locations  immediately  following  the 
opcode.  The  low  byte  of  the  address  immediately 
follows  the  opcode. 


Data  Flow: 


B  I 
D 
H 


1 

c 

E 

I 

Timing:  4  M  cycles;  13  T  states;  6.5  usee  @  2  MHz 

Addressing  Mode:  Direct. 
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Flogs:  5    z        H       p/v  N  c 

(no  effect) 


Example:  LD    (032  i),  A 

Before:  After: 

A  I       A4         I  A  I  A^ 


OBJECT  CODE 
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LD  (nn),  dd 


Load  memory  locations  addressed  by  nn  from 
register  pair  rr. 


Function: 
Format: 


(nn)  ^ddio^;  (nn  +  1)  "^ddhigh 


1  I  byte  1:  ED 
I     byte  2 


byte  3:  address, 
low  order 

byte  4:  address, 
high  order 


Descriptions:  The  contents  of  the  low  order  of  the  specified 

register  pair  are  loaded  mto  the  memory  location 
addressed  by  the  memory  locations  immediately 
following  the  opcode.  The  contents  of  the  high 
order  of  the  register  pair  are  loaded  into  the 
memory  location  immediately  following  the  one 
loaded  from  the  low  order.  The  low  order  of  the 
nn  address  occurs  immediately  after  the  opcode.dd 
may  be  anyone  of: 


BC  -  00 
DE  -  01 


HL  -  10 
SP  -  11 


321 


PROGRAMMING  THE  Z80 


Timing:  6  M  cycles;  20  T  states;  10  usee  @  2  MHz 

Addressing  Mode:  Direct. 


EO- 


BC 

DE 

HL 

SP 

43 

S3 

63 

73 

Flags: 


S     Z   H  P/V    N  C 


(no  effect). 


Example: 


LD    (040B),  BC 


Before: 


After: 


0221 


c  St 


0221 


-13 


OB 


04 


OBJEa 
CODE 


040B 
040C 


06 
AB 


040B 
040C 


m 
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LD  (nn),  HL      Load  the  memory  locations  addressed  by  nn from 
HL. 


Function: 
Format: 


Description: 


(nn)  *- 

L.  (nn  4- 

1) 

H 

0  j  0 

1 

0  j  0 

0 

1 

0 

E 


byte  2;  address, 
low  order 
byte  3:  address, 
high  order 


The  contents  of  the  L  register  are  loaded  into  the 
memory  location  addressed  by  the  memory  loca- 
tions immediately  following  the  opcode.  The  con- 
tents of  the  H  register  are  loaded  mto  the  memory 
location  immediately  following  the  location 
loaded  from  the  L  register.  The  low  order  of  the 
n'n  address  occurs  immediately  after  the  opcode. 


Data  Flow: 


Timing: 


5  M  cycles;  16  T  states;  8  usee  @  2  MHz 


Addressmg  Mode:  Direct. 
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Flags:  5    z       h       p/v  ^  ^ 

I  (no  effect). 


Example:  LD    (40B9),  HL 


Before:  After: 


OBJECT 
CODE 
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LD  (nn),  IX       Load  memory  locations  addressed  by  nn  from  iX. 


Function: 
Format: 


Description: 


(nn)     IXiovvJ  (nn  +  1) 


1 

0 

1 

i 

1 

0 

1 

0  j  a 

1 

0 

0 

0 

1 

0 

byte  I:  DD 

byte  2;  22 

byte  3:  address, 
low  order 

byte  4:  address, 
high  order 


The  contents  of  the  low  order  of  the  IX  register 
are  loaded  into  the  memory  location  addressed  by 
the  contents  of  the  memory  location  immediately 
following  the  opcode.  The  contents  of  the  high 
order  of  the  IX  register  are  loaded  into  the 
memory  location  immediately  following  the  one 
loaded  from  the  low  order.  The  low  order  of  the 
nn  address  occurs  immediately  after  the  op  code. 


Data  Flow: 


Timing:  6  M  cycles;  20  T  states;  10  usee  @  2  MHz 

Addressing  Mode:  Direct. 
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Flags: 


S  Z  H  P/V    N  C 


Example: 


LD    (01 2B),  IX 


OBJECT 
CODE 


After: 


DD 


22 


2B 


01 


012B 
Oi2C 


D3 

0!2B 

9A 

012C 
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LD  (nn),  lY        Load  memory  locations  addressed  by  nn  from  lY. 


Function: 
Format: 


Descnpiion: 


(nn^     lYio^;  (nn  +  1)  lY^igh 

byte  i:  FD 


I     I     I     I  I 


byte  2:  22 

byte  3:  address, 
low  order 

byte  4:  address, 
high  order 


The  contents  of  the  low  order  of  the  i  Y  register  are 
loaded  into  the  tnemory  location  addressed  by  the 
contents  of  the  memory  locations  immediately 
following  the  opcode.  The  contents  of  the  high 
order  of  the  FY  register  are  loaded  into  the 
memory  location  immediately  foliowmg  the  one 
loaded  from  the  low  order.  The  low  order  of  the 
nn  address  occurs  immediately  after  the  opcode. 


Data  Flow: 


Timing: 


6  M  cycles;  20  T  states;  10  usee  @  2  MHz 


Addressing  Mode:  Direct. 
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Flags: 


S     Z  H         PA'    N  C 


{no  effect) 


Example: 


LD  (BD04),  lY 


OBJECT  CODE 


Before: 


After; 


0204 


J  IY| 


0204 


FD 


22 


04 


6D 


B004 
BD05 


A5 


96 


BD04 
BD05 
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LD  A,  (BC)         Load  accumulator  from  the  memory  location  in- 
directly addressed  by  the  BC  register  pair. 


Funaion: 
Format: 

Descnpnoii: 


A  *-  (BC) 


0  0 


i  I  0       j  0  ]  OA 


The  contents  of  the  memory  location  addressed 
by  the  contents  of  the  BC  register  pair  are  loaded 
into  the  accumulator. 


Dala  Flow: 


Timing:                2  M  cycles;  7  T  states;  3.5  usee  @  2  MHz 
Addressing  Mode:  Indirect. 
Flags:  s  z   h  p/y  n  c  .. 


(no  effect). 


Example: 


OA 


OBJECT  CODE 


LD  A,  (EC) 
Before: 


A  AB 


32DI 


3201 


41 


32D1 
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LD  A,  (DE)       Load  the  accumulator  from  the  memory  location 
indirectly  addressed  by  the  DE  register  pair. 


Function:  A  (DE) 

Formal: 


0    0    0    !    !    a    i    0  lA 


Description:  The  contents  of  the  memory  location  addressed  by 

the  contents  of  the  DE  register  pair  are  loaded  mto 
the  accumulator. 


2  M  cycles;  7  T  states;  3.5  usee  @  2  MHz 


Timing: 
Addressing  Mode:  Indirect. 

Flags: 
Example: 


H  PA/   N  C 

j    I    I    I    j  (No  effect). 


LD  A,  (DE) 
Before; 


After; 


D2 


6051 


6051 


330 


LD  A,  I 


THE  Z80  INSTRUCTION  SET 
Load  accumulator  from  interrupt  vector  register  1, 


Funclion: 
Forma!: 


Description: 


A  *-  1 


J  J^lil^THZl  byte  1:  ED 
Er'  tEf^IILIll  byte  2:  57 

The  contents  of  the  interrupt  vector  register  are 
loaded  into  the  accumulator. 


Da  I  a  Flow: 


Timing: 


2  M  cycles;  9  T  states;  4.5  usee  @  2  MHz 


Addressing  Mode:  Implicit. 


Flags: 


Example: 


5  Z 


H         PA'   N  C 


• 

•1 

1 

o 

x|0 

LD  A,  ! 
Before: 


-Set  to  the  contents 
of  IFF2 


After: 


ED 


57 


OBJECT  CODE 


30 


J  'L 
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LD  I,  A  Load  Interrupt  Vector  register  1  from  the  ac- 

cumulator. 

Funclion:  I  A 


Format: 


1 

] 

i 

0 

1 

1 

0 

1 

byte  1 :  ED 

0 

1 

0 

0  1  0 

1 

1 

i 

byte  2;  47 

Description:  The  contents  of  the  accumulator  are  loaded  into 

the  Interrupt  Vector  register. 


Data  Flow:  a 


Timing:  2  M  cycles;  9  T  states;  4.5  usee  @  2  MHz 

Addressing  Mode:  Implicit. 

Flags:  5    z        h      f/v  n  c 

[  (no  effect) 

Example:  LD    I,  A 


Before: 


After: 


06        I  1  j  D2 


A  06 


ED 


OBJECT  CODE 
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LD   A,  R  Load  accumulator  frorn  Memory  Refresh  register 

R. 


Function: 
Format: 


A  R 


i 

1 

1 

0 

1 

1  [  0 

0 

1 

0 

1 

1 

1 

1  I  1 

byte  I:  EI> 
byle  2:  5F 


Description: 


The  contents  of  the  Memory  Refresh  register  are 
loaded  into  the  accumulator. 


Data  Flow: 


IC 


Timing:  2  M  cycles;  9  T  states;  4.5  usee  @  2  MHz 

Addressing  Mode:  Implicit. 
Flags: 


s 

z 

H 

P/V 

N 

c 

• 

• 

o| 

X 

O 

k  set  <o  contents  of  IFF2 


Example:  LD    A,  R 

Before: 


After: 


SF 


62 


4A 


OBJECT  CODE 
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LD   HL,  (nn)      Load  HL  register  from  memory  locations  addres- 
sed by  nn. 


Function: 


L     (nn);  H  -  (no  +  D 


Format: 


byte  1 :  2A 

byte  2:  address,  low 
order 

byte  3:  address,  high 
order 


Description:  The  contents  of  the  memory  location  addressed  by 

the  memory  locations  immediately  after  the  op- 
code are  loaded  into  the  L  register.  The  contents 
of  the  memory  location  after  the  one  loaded  into 
the  L  register  are  loaded  into  the  H  register.  The 
low  byte  of  the  nn  address  occurs  immediately 
after  the  opcode. 


Da!a  Flo  w: 


LD 


Timing:  5  M  cycles,  16  T  states;  8  usee  @  2  MHz 

Addressing  Mode:  Direct. 
Flags:  s    z        h        p/v  n  c 


J  {no  effect) 
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Example:  LD    HL,  (00241 


Before;  After; 


OBJECT  CODE 
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LD  IX,  nn 

Function: 

Format: 


Description: 


Load  IX  register  with  immediate  data  nn. 
IX  ^  nn 


1 

1 

0 

! 

1 

1 

0 

0 

0 

1 

0 

0 

0 

0 

r 

T  1  \  1  1  ;  p 


J  I  I  L_L 


'1 — i — ! — \ — r 


J  I  L 


byte  I :  DD 

byte  2:  21 

byte  3:  immediate 
data,  low  order 
byte  4:  immediate 
data,  high  order 


The  contents  of  the  memory  locations  immediate- 
ly following  the  opcode  are  loaded  into  the  IX 
register.  The  low  order  byte  occurs  immediately 
after  the  opcode. 


Data  Flow: 


Timing:  4  M  cycles;  14  T  states;  7  usee  @  2  MHz 

Addressing  Mode:  Immediate. 
Flags:   ^  h       p/v  n  c 


(no  effect) 
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Example:  LD    IX,  BOB  1 


Before: 


After: 


Bl 


BO 


IX 


306F 


OBJECT  CODE 
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LD   IX,  (nn)       Load  IX  register  from  memory  locations  ad- 
dressed by  nn. 


Function: 
Formal: 


5^1ow  *"  (nn);  IX^ig^     (nn  +  U 


byte  1;  DD 


[~ojo~|"  i  |T]  t  j  0  [  I  ]V]  byie  2;  2A 

E"T  r  i  1  !  I  r 
,j  !  1  2  1  J  I 


I      I      1  I  i 


byte  3:  address, 
low  order 

^  byte  4;  address, 


high  order 


Descriptions: 


Data  Flow: 


The  contents  of  the  memory  location  addressed  by 
the  memory  locations  immediately  foliowmg  the 
opcode  are  loaded  into  the  low  order  of  the  iX 
register.  The  contents  of  the  memory  location  im- 
mediately following  the  one  loaded  into  the  low 
order  are  loaded  into  the  high  order  of  the  IX  reg- 
ister. The  low  order  of  the  nn  address  immediately 
follows  the  opcode. 


^  L 


LD 


Timing:  6  M  cycles;  20  T  states;  10  usee  @  2  MHz 

Addressing  Mode:  Direct. 
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Flags:  5    z        h       pa^  n  c 

I    ]     I     1         \         I       (no  effect). 


Example:  LD    IX,  (01  OB) 


Before:  After: 


OBJECT  CODE 
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LD  lY,  nn 

Function: 

Format: 


Load  lY  register  with  immediaie  data  nn. 
lY  nn 


0 

0 

1 

0 

0 

0 

0 

i 

 1  j„ 

— " — n-™™- 

J  I  L 


byte  !:  FD 

byie  2:  21 

byie  3;  immediate 
data,  low  order 
byie  4;  immediate 
data,  high  order 


Description:  The  contents  of  ihe  memory  locations  immediate- 

ly foUowmg  the  opcode  are  loaded  into  the  lY 
register.  The  iow  order  byte  occurs  immediateiy 
after  the  opcode. 


Data  Flow: 


Timing:  4  M  cycles;  14  T  states;  7  usee  @  2  MHz 

Addressing  Mode:  Immediate. 
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Flags: 


s     z  H        P/V    N  c 


(no  effect) 


Example: 


LD    lY,  21 


FD 


2i 


00 


Before: 


lY  069B 


After: 


OBJEa  CODE 
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LD  lY,  (nn)        Load  register  lY  from  memory  locations  addressed 
by  nn. 


Furidton: 
Format: 


I^low  *-  (nn);  lYhigh  ^  (nn  +  1) 


byte  i:  FD 


ZIZIZIZIZ]  ^y^^  ^- 


-J  !  1  1  r- 

 n  —  


-T  \  !  !  1  1  T" 


_1  I  1  L  L. 


byte  3:  address, 
low  order 

byte  4;  address, 
high  order 


Description:  The  contents  of  the  memory  location  addressed  by 

the  memory  locations  immediately  following  the 
opcode  are  loaded  into  the  low  order  of  the  lY 
register.  The  contents  of  the  memory  location  im- 
mediately following  the  one  loaded  into  the  low 
order  are  loaded  into  the  high  order  of  the  iY 
register.  The  low  order  of  the  nn  address  im- 
mediately follows  the  opcode. 
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Timing:  6  M  cycles;  20  T  states;  !0  usee  @  2  MHz 

Addressing  Mode:  Direct. 


Flags: 


S      Z  H  P/V  N  C 


(no  effect). 


Example: 


LD    lY.  (500D) 


Before: 


After: 


lY  ! 


6002 


m 


2A 


QD 


SO 


OBJECT 
CODE 


50QD 
500E 


03 


500D 
500E 


03 
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LD  R,A 

Function: 
Formal: 


Load  Memory  Refresh  register  R  from  the  ac- 
cumulator. 


R  A 


1 

1 

1 

0 

i 

i 

0 

1 

0 

i 

0 

0 

i 

i 

byte  I:  ED 
byte  2:  4F 


Description: 


Data  Flow: 


The  contents  of  the  accumulator  are  loaded  into 
the  Memory  Refresh  register. 


Timing:  2  M  cycles;  9  T  states;  4.5  usee  @  2  MHz 

Addressing  Mode:  Implicit. 


Flags: 


SI  H         PA/    N  c 


(no  effect) 


Example: 


LD    R,  A 


ED 


4F 


Before: 


After: 


\\        OF        I  R I        40      "I  A  r      OF        j  R  Mf&tWM 


OBJECT  CODE 
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LD  SP,  HL        Load  stack  pointer  from  HL. 


Function: 
Format: 


SP  *-  HL 


Description:  The  contents  of  the  HL  register  pair  are  loaded  in- 

to the  stack  pointer. 


Data  Flo  w: 


Timing: 


I  M  cycles;  6  T  states;  3  usee  @  2  MHz 


Addressing  Mode:  Implicit. 

Flags:  s    z        h       p/v  n  c 

 '         \    (no  effect) 


Example:  LD   SP,  HL 


Before:  After; 


OBJECT 
CODE 


345 


PROGRAMMING  THE  Z80 


LD  SP,  IX         Load  stack  pointer  from  IX  register. 


Function: 
Formal: 


Description: 
Data  Flow: 


SP  *~  IX 


s    !    0    0    I    (    0    I     byte  i :  DD 


QIZninitHI]  ^y''  2:  F9 


The  contents  of  the  IX  register  are  loaded  into  the 
stack  pointer. 


Timing:  2  M  cycles;  10  T  states;  5  usee  @  2  MHz 

Addressing  Mode:  ImpHcit. 

Flags:  s    z        h      p/v   n  c 


Example: 


LD    SP.  IX 


Before: 


After: 


DP 
F9 


OBJECT 
CODE 


SP 


09D2 


09D2 


5AA0 
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LD  SP,  lY  Load  stack  pointer  from  lY  register. 


Fundton: 
Formal: 


SP  *-  lY 


byte  1 :  FD 
byte  2:  F9 


Description: 


Data  Flow: 


Timing: 


The  contents  of  the  !  Y  register  are  loaded  into  the 
stack  pointer. 


2  M  cycles;  10  T  slates;  5  usee  @  2  MHz 


Addressing  Mode:  Implicit. 
Flags:  s    z        h       pa/  n  c 


Example: 


LD  SP,  iY 
Before: 


(no  effect) 


Afier: 


FD 


F9 


OBJECT  CODE 


IY 


SP 


09AB 


isOOA 


0VA6 
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LDD  Block  load  with  decrement. 


Function:  (DE)  -  (HL);  DE  ^  DE  -  1 ;  HL     HL  -  1 ; 

BC  *"  BC  -  1 

Format: 

I     I     I    0    I     I    0    I      byte  !:  ED 


!    0    s    0    s    0    0  I  0     byte  2:  A8 


Description:  The  contents  of  the  memory  location  addressed  by 

HL  are  loaded  into  the  memory  location  address- 
ed by  DE.  Then  EC,  DE,  and  HL  are  all 
decremented. 


Data  Flow: 


Timing:  4  M  cycles;  16  T  states;  8  usee  @  2  MHz 

Addressing  Modes:  Indirect. 


Flags: 


PA'    N  c 


o 

X 

o 

•  Reset  if  BC  =  0  after 
execution,  set  otherwise. 
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LDD 
Before: 


THE  Z80  INSTRUCTION  SET 
After: 


PROGRAMMING  THE  Z80 


LDDR 


Repeating  block  load  with  decremenu 


Funclton: 


(DE)  *-  (HL);  DE  ^  DE  -  1;  HL  -  HL 
BC  ^  BC  -  1;  Repeat  until  BC  =  0 


Format: 


byte  !:  ED 


I  0 


10    0    0      byte  2:  B8 


Description: 


Data  Flow: 


The  contents  of  the  memory  location  addressed  by 
HL  are  loaded  into  the  memory  location  address- 
ed by  DE.  Then  DE,  HL,  and  BC  are  all 
decremented.  If  BC  ^  0,  then  the  program  counter 
IS  decremented  by  2  and  the  instruction  re- 
executed. 


Timing: 


BC  it  0:  5  M  cycles;  2!  T  states;  10.5  usee  @  2 
MHz. 

BC  =  0:  4  M  cycles;  16  T  slates;  8  usee  @  2  MHz 


Addressing  Mode:  Indirect 
Flags: 


s  2 


PA'    N  C 


o 
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Example:  LDDR 

Before:  After: 


0003 

C 

B 

^oooc 

06B2 

E 

D 

m 

1  9035 

L 

H 

f 

m 

9032 
9033 
9034 
9035 


92 


9032 
9033 
9034 
9035 


92 


OE 


BF 
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LDI 


BlodE  load  with  increniait. 


Fttmiim.' 


Format: 


(DE)  *-  (HL);  DE    DE  +  1;  HL    HL  +  I : 

m    B  c  -  1 


1 

1 

I 
1 

3 

1 

1 

0 

1 

0 

0 

0 

0 

0 

byte  1:  ED 


Description:  The  contents  of  the  memory  location  addressed  by 

Hl^re  feaiid  tfltd  the  memory  locatfoiH  aiiSiii^ 
by  DE.  Then  both  DE  and  HL  are  incremated, 
and  the  register  pair  BC  is  decremented. 


Timing: 


s  z 


P/V   N  C 


O     X  o 


Reset  if  BC  =  0  after 
execution,  set  otherwise. 


THf  Z80  INSTRUCTION  SET 


Example; 


Before; 


After: 


0006 
34B1 


ma 


.0005 


ED 


AO 


34B1 


OA 


39Q2 


PROGRAMMING  THE  Z80 


LMR  Repeating  block  load  with  increment. 


Funcuon:  (DE)  *-  (HL);  DE  ^  DE  +  1 ;  HL  ^  HL  -f-  i : 

BC  *~  BC  -  ! ;  Repeat  until  EC  =  0 

Formal:   


I 

i 

i 

0 

! 

i 

0 

1 

1 

0 

1 

1 

0 

0 

0 

0 

byte  i:  ED 
byte  2:  BO 


Description:  The  contents  of  the  memory  location  addressed  by 

HL  are  loaded  into  the  memory  location  ad- 
dressed by  DE.  Then  both  DE  and  HL  are  in- 
cremented. BC  is  decremented.  If  BC  0  then 
the  program  counter  is  decremented  by  2  and  the 
instruction  is  re-executed. 


Timing:  For  BC  ^  0:  5M  cycles;  21  T  states;  10.5  usee  @  2 

MHz. 

For  BC  -  0:  4  M  cycles;  16  T  states:  8  usee  @  2 
MHz 

Addressing  Mode:  indirect. 
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Flags: 


p/v  N  c 


O  OO 


Example: 


LDIR 


Before; 


After: 


ax)2 

4A03 


962A 


ED 


BO 


4A03 
<SA05 


12 


F4 


OBJECT  CODE 


4A03 
4A04 
4A0S 


AA 


962A 
962B 


3B 
6E 


962A 
962B 
962C 


90 
6E 
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LD  r,  (HL)  Load  register  r  indirect  from  memory  location 


X  *-  OIL) 


1 

 ,!.,*„  ■ 

\ 

\ 

Desari/alon:  The  contents  of  the  memory  location  addresmi  by 

HL  are  loaded  into  the  specified  register,  r 

may  be  any  one  of: 


A  -  HI 
B  -  000 
C  -  001 
D  -  010 


E  -  Oil 
H  -  100 
L  -  101 


DM9  Fktw: 


A 
B 
D 
H 


C 
E 

L- 


11 


DATA 


2  M  cy«^;  7  T  stam;  3.5  mm  %  %  MHz 


Byte  Codes: 


A  B 


n 

■4d 

4E 

56, 

s 

AE 

356 
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NEG 


mmmulaMcfr. 


Fmmt: 


1      T      1      0     1      1      0  1 


byte  1:  £D 
byte  2: 44 


Deseiifitkm:  The  contents  of  the  accumulator  are  subtracted 

from  zero  (two's  complement)  and  the  result  is 
^ored  back  in  the  acciiiaa3N£ij^» 


Timing:  2  M  eytie^  8  T  stiues;  4  usee  @  2  MHz 

Addressing  Mode:  Iinpiiit, 


ED 


44 


OBJta 
coot 


5  z 


H        ®/V   N  C 


C  will  be  set  if  A  was  0  before  the  instruction. 
pwiUbesetifAwiis8QIH. 


NEG 

Before: 

^1  M 


After: 
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Function: 

Format: 

Descripiion; 
Data  Flow: 


0 

0 

0 

0 

0 

0 

0 

0 

Nothing  is  done  for  1  M  cycle. 


No  actioai 
c 


1  M  cydei  *  T  states;  2  usee  @  2  MHz 
Addressing  Mode:  Implicit 


s  z 


PA/  N  C 


(no  effect). 


PROGRAMMING  THE  Z80 

OR  S  Logical  or  accumulator  and  operand  s. 


Function: 
Format: 


A  *-  A  V  s 

s;  may  be  r,  n,  (HL),  (IX+  d),  or  (IY+  d) 


(HL) 
(IX  +  d) 


(lY  +  d) 


T  r 

— H  ^™  

J  L. 


-l      ^      ,  1  1  5  ^ 


byte  1;  F6 

byte  ; 
data 


I    '  .  j  byte  2:  immediate 


1 

Q 

1 

i 

0 

i 

1 

0 

1 

1 

0 

1 

i 

1 

0 

1 

! 

0 

s 

i 

0 

[ 

s 

0 

-l      I      I  ,  1  1  1_ 


-i  1  1  1  I   I 


I  0 


"T      I  1  1  1  1  r 


-1  1  1  I  I  I  I 


byte  1:  B6 

byte  1:  DD 

byte  2:  B6 

byte  3:  offset  value 

byte  i;  FD 

byte  2:  B6 

byte  3:  offset  value 


r  may  be  any  one  of: 


A  ~  ill 
B  -  000 
C  -  GDI 
D  -  010 


E  -  Oil 
H  -  100 
L  -  101 


Description:  The  accumulator  and  the  specified  operand  are 

logically  'or'ed,  and  the  result  is  stored  in  the  ac- 
cumulator, s  is  defined  in  the  description  of  the 
similar  ADD  instructions. 
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Data  Flow: 


Timing: 


usee 

s: 

M  cycles: 

T stales: 

@  2  MHz: 

r 

1 

4 

4 

n 

2 

7 

3.5 

(HL) 

7 

3.5 

(IX  +  d) 

5 

!9 

9.5 

(lY  +  d) 

5 

19 

9.5 

Addressing  Mode:    r:  implicit;  n:  immediate;  (HL);  indirect;  (IX  + 
d),  (lY  4-  d):  indexed. 


Byte  Codes: 

OR  r 

r: 

A 

B 

C 

0  £ 

H 

I 

B7 

BO 

B) 

B2  1  B3 

%A 

BS 

Flags: 
Example: 


s 

z 

H 

c 

® 

m 

o 

o 

O 

OR  B 


OBJECT 
CODE 


Before: 


06 


After: 


B9 
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OTDR 


Block  output  with  decrement 


Function: 
Format: 


(C)^{HL);B-B  -  1;HL^HL  -  l\ 
Repeat  until  B  =  0. 


[ 

1 

1 

0 

! 

i 

0 

1 

i 

0 

s 

1 

i 

0 

byte  1:  ED 
byte  2:  BB 


Description:  The  contents  of  the  memory  location  addressed  by 

the  HL  register  pair  are  output  to  the  peripheral 
device  addressed  by  the  contents  of  the  C  register. 
Both  the  B  register  and  the  HL  register  pair  are 
then  decremented.  If  B  0,  the  program  counter 
IS  decremented  by  2  and  the  instruction  is  re- 
executed.  C  supplies  bits  AO  to  A7  of  the  address 
bus.  B  supplies  (after  decrementation)  bits  A8  to 
A15. 


Data  Flow: 


A 

B 

fcoy.NfERl 

c 

D 

E 

H 



,: 

L 

PORT 


Timing: 


B  =^  0:  4  M  cycles;  16  T  states;  8  usee  @  2  MHz. 
B  ?^  0:  5  M  cycles;  21  T  states;  10.5  usee  @  2  MHz 


Addressing  Mode:  External. 


Flags: 


5      2  H         P/V    N  C 
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Example:  OTDR 


Before:  After: 


b|         02        I         E5        |C        B  WMMWM        ^         \  ^ 
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OTIR  Biock.  output  With  mcrement. 


Funcuon:  (C)  ^  (HL);  B  -  B  -  I;  HL     HL  +  j;  Repeat 

until  B  =  0 

Fornwi:    ._   ._   _   

'  I  '  r"'T  °  h  1  '1  °  I  '1  byte  1:  ED 


1 

0 

i 

i 

0  jo 

1 

1 

byte  2;  83 


Descnptton:  The  contents  of  the  memory  location  addressed  by 

the  HL  register  pair  are  output  to  the  peripheral 
device  addressed  by  the  contents  of  the  C  register. 
The  B  register  is  decremented  and  the  HL  register 
pair  IS  incremented.  If  B  #  0,  the  program  counter 
is  decremented  by  2  and  the  instruction  is  re- 
executed.  C  supplies  bits  AO  to  A7  of  the  address 
bus.  B  supplies  (after  decrementation!  bits  AS  to 
A15. 


Data  Flow: 


A 

B 

D 

H 

pii 

PORT 


Timing:  q  ^  q.  ^     cycles;  16  T  states;  8  usee  @  2  MHz. 

B  #  0:  5  iVl  cycles;  21  T  states;  10.5  usee  @  2  MHz 


Addressing  Mode:  External. 


Flags:  5    z        h       p/v  n  c 
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Example: 


OTIR 


Before: 


After: 


03 


5550 


AO 


as  I  PORT 
AO 


AO 


ED 

5S50 

6B 

B3 

5S51 

02 

SSS2 

9A 

OBJECT  CODE 

5553 

45 

5550 

6B 

555! 

02 

5552 

9A 

5SS3 

65 
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OUT  (C),  r 


Output  register  r  to  port  C. 


Function: 
Formal: 


Description: 


Data  Flow: 


(C)  *-  r 


1 

1 

1 

0 

i 

s 

byte  i :  ED 

0 

■■■  I  i  s  ■— 

1       i  '  1 

0 

0 

1 

byte  2 

The  contents  of  the  specified  register  are  output  to 
the  peripheral  device  addressed  by  tfie  contents  of 
the  C  register,  r  may  be  any  one  of: 


A  -  111 

B  -  000 

C  -  001 

D  -  010 


E  -  01! 
H  -  100 
L  -  101 


Register  C  supplies  bits  AO  to  A7  of  the  address 
bus.  Register  B  supplies  bits  AS  to  A15. 


Timing: 


ED- 


3  M  cycles;  12  T  states;  6  usee  @  2  MHz 


Addressing  Mode:  External 
Flags: 

Byte  Codes: 


5 

Z 

H 

P/V 

N 

C 

A 

B 

C 

D 

E 

H 

L 

79 

41 

49 

51 

59 

61 

69 

(no  effect). 
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Example: 


OUT  (C),  B 


Before: 


After: 


£D 


B  09 


B8 


OBJECT  CODE 


JC        B|  D9 

Iport 
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OUT  (N),  A        Output  accumulator  to  peripheral  port  N. 


Function: 
Format: 

Description: 


Data  Flow: 


Timing: 


(N)  -  A 


1 

1 

0 

1 

0 

0 

1 

1 

J  I  L 


byte  2:  port  address 


The  contents  of  the  accumulator  are  output  to  the 
peripheral  device  addressed  by  the  contents  of  the 
memory  location  immediately  following  the  op- 
code. 


PORT 


OUT 


3  M  cycles,  U  T  states;  5.5  usee  @  2  MHz 


Addressmg  Mode:  External. 
Flags: 


S     Z  H         PA^    N  C 


(no  effect). 


Example:  OUT   (OA),  A 

Before: 


After; 


D3 


OA 


OBJECT  CODE 


_FF_JpofiT  a|  si  I  l^gsi^^PORT 
OA  OA 
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OUTD 


Output  with  decrement. 


Function: 
Formal: 


(C)  *-  (HL);  BC  ^  B  -  1;  HL      HL  -  1 


1 

1 

1 

0 

1 

1 

0 

1 

1 

0 

i 

0 

1 

0 

1 

1 

byte  I:  ED 
byte  2:  AB 


Description:  The  contents  of  the  memory  location  addressed  by 

ihe  HL  register  pair  are  output  to  the  peripheral 
device  addressed  by  the  contents  of  the  C  register. 
Then  both  the  B  register  and  the  HL  register  pair 
are  decremented.  C  supplies  bits  AO  toA7of  the 
address  bus.  B  supplies  (after  decrementation)  A8 
toAiS. 


Data  Flo  w: 


B  ;  COUNTER 
D 
H 


PORT 


DATA 


Timing: 


4  M  cycles;  16  T  states;  8  usee  @  2  MHz 


Addressing  Mode:  External. 


Flags: 


P/V   N  c 


Set  if  B  =  0  after  execution, 
reset  otherwise. 
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Example: 


OUTD 


Before: 


After: 


B  30 


9A       c  a 


9A 


22BF 


L  H 


06  PORT 


9A 


'mbWM  POST 


ED 


OBJECT  CODE 


32BF 


22Bf 


Ah 
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OUTI 


Output  with  increment. 


Function: 
Format: 


Description: 


Data  Flow: 


(C)  -  (HL);  B  -  B  -  i ;  HL  -  HL  +  1 


! 

! 

1 

0 

t 

\ 

0 

i 

1 

0 

1 

0 

0 

0 

1 

! 

byte  1:  ED 
byie  2:  A3 


The  contents  of  the  memory  location  addressed  by 
the  HL  register  pair  are  output  lo  the  peripheral 
device  addressed  by  the  C  register.  The  B  register 
is  decremented  and  the  HL  register  pair  is  incre- 
mented. 

C  suppUes  bits  AO  to  A7  of  the  address  bus. 

B  (after  decrementation)  supplies  bits  A8  to  A15. 


0coun!er  ^ 

PORT 


DATA 

Timing:  4  M  cycles;  16  T  states;  8  usee  @  2  MHz 

Addressing  Mode:  ExternaL 

Flags: 


s  z 


?/y  H  c 


Set  if  B  =  0  after  execution, 
reset  otherwise. 
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Example:  OUTI 


Before: 


After: 


ED 


OBJECT  CODE 


0F9A 


BB 


02 


0F9A 


Iport 


BB 


BB 


0F9A 


372 


THE  ZaO  INSTRUCTION  SET 


POP  qq 


Pop  register  pairqq  from  stack. 


Function: 
Format: 


'J'^iow  ^  (SP);  ^^high^  (SP  +  i);  sp-  sp  +  2 


q  q 


Description:  The  contents  of  the  memory  location  addressed  by 

the  stack  pointer  are  loaded  into  the  low  order  of 
the  specified  register  pair  and  then  the  stack 
pointer  is  incremented.  The  contents  of  the 
memory  location  now  addressed  by  the  stack 
pointer  are  loaded  into  the  high  order  of  the 
register  pair,  and  the  stack  pointer  is  again  in- 
cremented, qqmay  be  any  one  of: 


BC  -  00 
DE  -  01 


HL  - 

AF  - 


10 
11 


Data  Flow: 


A 
B 
D 
H 


DATA 


Timing: 


3  M  cycles;  10  T  states;  5  usee  @  2  MHz 


Addressing  Mode:  Indirect. 
Byte  Codes: 


BC 

DE 

HI 

AF 

Ci 

Dl 

El 

Fl 
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Flags:  s    2       _h  _  p/v  n  c 

ctt:i.i:t;"[X] 

Example:  POP  BC 


Before:  After: 
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POP  IX 


POP  IX  register  from  stack. 


Funciion: 
Formal: 


''^low  ^  <SP);  iX^,^^  ^  (SP  +  1);  SP     SP  +  2 


1 

1 

i 

i   1  0 

i 

j  t 

1  J   1  j  0  j  0 

0  j  0 

1 

byte  1:  DD 


Descripnon:  The  contents  of  the  memory  location  addressed  by 

the  slack  pointer  are  loaded  into  the  low  order  of 
the  IX  register,  and  the  stack  pointer  is  in- 
cremented. The  contents  of  the  memory  location 
now  addressed  by  the  stack  pointer  are  loaded  in- 
to  the  high  order  of  the  IX  register,  and  the  stack 
pointer  is  again  mcremented. 


Data  Flo  w. 


A 
B 
D 
H 

iXl 


DATA 


Timing: 


4  M  cycles;  14  T  states;  7  usee  @  2  MHz 


Addressing  Mode:  Indirect. 
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Flags:  5    z        h       p/v  n  c 

I  [    I       (no  effect). 

Example:  POP  IX 

Before:  After: 

sp|        0908        I    sp  WMiMM^^^. A 
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POPIY 


POP  lY  register  from  slack. 


Funclion: 
Formal: 


^^low^^SP);  lY,,g,-(SP^  l);SP^SP-^2 


i 

1 

i 

1 

i 

i 

0 

i 

byie  1:  FD 

1 

1 

1 

0 

0 

0 

0 

i 

byie  2:  El 

Descnpiion:  The  contents  of  the  memory  locatson  addressed  by 

the  stack  pomter  are  loaded  mio  the  low  order  of 
the  (Y  register,  and  then  the  stack  pomter  is  incre- 
mented. The  contents  of  the  memory  location  now 
addressed  by  the  stack  pointer  are  loaded  mto  the 
high  order  oT  the  I Y  register,  and  the  stack  pointer 
is  again  incremented. 


Data  Flow: 


A 
B 
D 

H 

iVl 


7\ 


DATA 


Tiiutiig:  4  M  cycles;  14  T  states;  2  usee  @  2  MHz 

Addressing  Mode:  Indirect. 


Flags: 


s     z         H        P/V  N  c 


(no  effect). 
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Example:  POP  lY 


Before:  After: 
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PUSH    qq  Push  register  pair  onto  stack. 


Function:  (SP  -  I )  ^qqhighi  (SP  -  2)-qqiowi 

SP--SP  -  2 

Fonnat: 


q  ,  q  0 


Description:  The  stack  pointer  is  decremented  and  the  contents 

of  the  high  order  of  the  specified  register  pair  are 
then  loaded  inio  the  memory  location  addressed 
by  the  stack  pointer.  The  slack  pointer  is  again 
decremented  and  the  contents  of  the  low  order  of 
the  register  pair  are  loaded  into  the  memory  ioca- 
uon  currently  addressed  by  the  stack  pointer,  qq 
may  be  any  one  of: 

BC  -  00  HL  -  10 

DE  -  01  AF  -  11 


Addressing  Made:  Indirect. 
Bvie  Codes:        11:  ec  de  hl  af 


C5 


05 


65 


f5 
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Flags:  s    z        h      pa'  n  c 

I    I    I    I    I    I     I    I    !  (no  effect). 


Example:  PUSH  DE 

Before:  After: 


D  I  OA03  I  E  D I  0A03 
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PUSH  IX 


Push  IX  onto  slack. 


Function: 


Formal: 


Descripuon: 


(SP 
SP 


SP  -  2 


2)  IXjo^y, 


□  I  I  I  I  j  I  ]  0  I  I  I  byte  1;  DD 


1 

1 

1 

0 

0  [  i 

0 

i 

byte  2:  E5 


The  stack  pointer  is  decremented,  and  the  conienis 
of  the  high  order  of  the  IX  register  are  loaded  into 
the  memory  location  addressed  by  the  slack 
pomter.  The  slack  pomler  is  again  decremented 
and  then  the  contents  of  the  low  order  of  the  IX 
register  are  loaded  into  the  memory  location  ad- 
dressed by  the  stack  pomier. 


Data  Flow: 


Timing:  41VI  cycles;  15  T  states;  7.5  usee  @  2  MHz 

Addressing  Mode-  Indirect. 


Flags: 


s  z 


P/V    N  C 


]  (no  effect) 
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Example:  PUSH  !X 


Before:  After; 
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PUSH  lY 


Push  lY  onto  stack. 


Fiinciton: 
Fo  111  nil: 


Descriplion: 


(SP  -  l)'-lYh,g|,;(SP 
SP  -  SP  -  2 


D"  L'  HI '  L'  1 '  [  °  I  l]  ^'^^^  *  - 


_1  I  ^ 


0  ;  8  ;  byte  2:  E5 


The  stack  pointer  is  decremented  and  the  contents 
of  the  high  order  of  the  )Y  register  are  ioaded  into 
the  memory  location  addressed  by  the  slack 
pointer.  The  stack  pointer  is  again  decremented 
and  the  contents  ofthe  low  order  of  ihe  (Y  register 
are  ioaded  into  the  memory  iocatiors  addressed  by 
ilic  stack  pointer. 


Daiu  Flow 


i 


Timing:  3  M  cycles;  15  T  states;  7.3  usee  @  2  MHz 

A  dclressing  Mock:  Indirect. 


Flags: 


S      Z  H  P/V     N  C 


(no  effect) 
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Example:  PUSH  lY 
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RES  b,s 

Function: 
Format: 


s: 
r 


(HL) 
(IX  +  d) 


(lY  +  d) 


Reset  bit  b  of  operand  s, 
S{j  *-  0 


i 

1 

0 

0 

1 

0 

1 

1 

byte  1:  CB 

i 

0 

1  1 

1  1 

1  1 
i  '  1 

byte  2 

t 

( 

0 

0 

i 

0 

i 

1 

byte  1:  CB 

1 

0 

 i  1  

 1  J  

1 

1 

0 

byte  2 

1 

1 

0 

0 

i 

0 

1 

1 

"1  i  i  1  1 — T  r 

 d  

J  I  !  I  1  I  i 


— b— 

_j  L. 


1  i~ 

-d- 


J  I  t  i  I  1 


0 

t  i 

1 

( 

(  1 

byte  1:  DD 

byte  2:  CB 

byte  3:  offset  value 

byte  4 
byte  1 :  FD 
byte  2:  CB 
byte  3:  offset  value 
byte  4 


b  may  be  any  one  of: 


0  -  000  4  -  iOO 

1-  001  5  -  101 

2-  010  6-110 

3-  011  7  -  III 


r  may  be  any  one  of: 


A  -  111  E  -  Oil 

B  -  000  H  -  100 

C  -  001  L  -  101 
D  ™  010 
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Description:  The  specified  bit  of  the  location  determined  by  s  is 

reset,  s  is  defined  in  the  description  of  the  similar 
BIT  instructions. 


Data  Flow: 

A 


Timing: 


s: 

M  cycles: 

T states: 

usee 
@  2  MHz: 

r 

1 

8 

4 

(HL) 

4 

15 

7.5 

(IX  +  d) 

6 

23 

11.5 

(lY  +  d) 

6 

23 

11.5 

Addressing  Mode:   r:  implicit;  (HL):  indirect;  (IX  +  d),  (lY  +  d):  in- 
dexed. 


Byte  Codes: 


RES    b,  r 


CB— 


b:  ' 
0 

;  A 

B 

C 

0 

E 

H 

I 

67 

80 

61 

82 

83 

64 

85 

1 

8F 

88 

89 

8A 

88 

8C 

8D 

2 

97 

90 

91 

92 

93 

94 

95 

3 

9F 

98 

99 

9A 

9B 

9C 

9D 

A 

A7 

AO 

A! 

A2 

A3 

A4 

A5 

5 

AF 

A8 

A9 

AA 

AB 

AC 

AO 

6 

B7 

BO 

Bl 

02 

B3 

B4 

B5 

7 

BF 

B8 

89 

BA 

BB 

ac 

BD 

b:0      !  234567 


RES    b,  (HL)  CB-. 


86 

SI 

96 

9£ 

A6 

AE 

B6 

BE 
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RES  r/(HL) 


Flags: 


DDCB  - 

b: 

0 

1 

2 

3 

4 

5 

6 

7 

CB  - 
FDCB 

86 

8E 

96 

9E 

A6 

AE 

as 

BE 

S  Z 

H 

P/V 

N 

C 

1  1 

(No  effect) 

Examples: 


RES    1,  H 


Before: 


After: 


CB 


BC 


OBJECT  CODE 
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RET 


Return  from  subroutine 


Function: 


Formal: 


PCiow  ^  (SP);  PChigh  ^  (SP  +  I):  SP  -  SP  +  2 


1 

1 

0 

0 

i 

0 

0 

! 

Description:  The  program  counter  is  popped  off  the  stack  as 

described  for  the  POP  instructions.  The  next  in- 
struction fetched  is  from  the  location  pointed  to 
by  PC. 


Data  Flow: 


STACK 


PCL  *n 


PCH 


Timing:  3  M  cycles;  10  T  states;  5  usee  @  2  MHz 

Addressing  Mode:  Indirect. 
Flags: 


S      Z  H         PA^  N  C 


{no  effect) 
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Example: 


RET 


Before: 


After: 


PCI 
SPf 


0BB1 


3310 


C9 


33?0 
3311 


OBJECT  CODE 


B4 


3310 
33!! 


84 
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RETcc 


Return  from  subroutine  on  condition. 


Function: 
Format: 

Description: 


If  cc  true;  PCjow  (SP);  PChigh  ^  (SP  +  D; 
SP-SP  +  2 


1 — r 


If  the  condition  is  met,  the  contents  of  the  pro- 
gram counter  are  popped  off  the  stack  as  described 
for  the  POP  instructions.  The  next  instruction  is 
fetched  from  the  address  in  PC.  If  the  condition  is 
not  met,  instruction  execution  continues  in 
sequence. 


Data  Flow: 


SP 


C0NTi50l 
LOGC 


STACK 

PCL 

PCH 

CC  may  be  any  one  of: 

NZ  -  000  PO  -  100 

Z  -  001  PE  -  lOI 

NC  -  010  P  -  ilO 

c  -  on  M  -  111 


Timing: 


Condition  met:  3  M  cycles;  1 1  T  states;  6.5  usee  @ 
2  MHz. 

Condition  not  met:  1  M  cycle;  5  T  states;  2,5  usee 

@  2  MHz 


Addressing  Mode:  Indirect. 
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By!e  Codes: 


CC.    NZ    Z     NC   C    PO    PE     P  M 


CO 

ce 

DO 

D8 

EO 

E8 

FO 

F8 

Flags: 


(no  effect) 


Example: 


RET  NC 


Before: 


After: 


PC) 

sp ! 


00 


0134 


SS!! 


DO 


OBJECT  CODE 


85n 
B5!2 


J5_ 

Bt 


851: 
8512 


85 


B1 
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RETI 

Function: 
Format; 


Return  from  interrupt. 


PCiow  ^  (SP);  PChigh  ^  {SP  +  1);  SP  -  SP  +  2 


ZEI 


byte  1:  ED 
byte  2:  40 


Description:  The  program  counter  is  popped  off  the  stack  as 

described  for  the  POP  instructions.  This  instruc- 
tion is  recognized  by  Zilog  peripheral  devices  as 
the  end  of  a  peripheral  service  routine  so  as  to 
allow  proper  control  of  nested  priority  interrupts. 
An  EI  instruction  must  be  executed  prior  to  RETI 
in  order  to  re-enable  interrupts. 


Data  Flow: 


Timing: 


4  M  cycles;  14  T  states;  7  usee  @  2  MHz 


Addressing  Modes:  Indirect. 


Flags: 


S  Z   H  P/V   N  C 


(no  effect). 
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Example: 


RETI 


Before: 


84E1 


89B2 


ED 


89B2 
B9B3 


A4 


89B2 
3983 


Bt 


OBJECT  CODE 
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RETN 


Return  from  non-maskable  interrupt. 


Function: 
Format: 


PCiow  *~  (SP);  PChigh  -  {SP  +  1);  sp  -  sp  + 

2;  IFF1  -  IFF2 


0  I 


byte  1:  ED 


0   0   0    i    0    i      byte  2:  45 


Description:  The  program  counter  is  popped  off  the  stack  as 

described  for  the  POP  instructions.  Then  the  con- 
tents of  the  IFF2  (storage  flip-flop)  is  copied  back 
into  the  IFFl  to  restore  the  state  of  the  interrupt 
flag  before  the  non-maskabie  interrupt. 


Data  Flow: 


Timing: 


4  M  cycles;  14  T  states;  7  usee  @  2  MHz 


Addressing  Mode:  Indirect. 
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Flags: 


s     z  H        P/V    N  c 


(no  effect). 


Example: 


RETN 


Before: 


After: 


PC  [ 


A5F1 


8B<fC 


PC 


OBJECT  CODE 


8BJC 

01 

aB4C 

01 

BB4D 

9A 

8640 

9A 
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RL  S 


Rotate  left  through  carry  operand  s. 


Function: 


Formal: 


(HL) 
(IX  +  d) 


(lY  +  d) 


1 

1 

0  j  0 

1 

0 

1 

1 

byte  1:  CB 
byte  2 
byte  J :  CB 
byte  2:  16 

0  j  0 

1 

0 

1  1 

1  1 

! 

i 

0 

Q 

1 

0 

1 

1 

0 

0  1  0 

1 

0 

1 

1 

0 

J  L 


L  i  L 


1  1  ^ — I — 1  r 


byte  1:  DD 

byte  2:  CB 

byte  3;  offset  value 

byte  4:  16 

byte  1:  FD 

byte  2:  CB 

byte  3:  offset  value 

byte  4:  16 


r  may  be  any  one  of: 

A  -  ill  E  -  Oil 

B  -  000  H  -  100 

C  -  001  L  -  101 
D  -  010 


Description:  The  contents  of  the  location  of  the  specific 

operand  are  shifted  left  one  bit  place.  The  con- 
tents of  the  carry  flag  are  moved  to  bit  0  and  the 
contents  of  bit  7  are  moved  to  the  carry  flag.  The 
final  result  is  stored  back  in  the  original  location,  s 
is  defined  in  the  description  of  the  similar  RLC  in- 
structions. 
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Data  Flow: 

A 
B 

D 
H 


Timing: 


usee 

s: 

M  cycles: 

T stales: 

@  2  MHz: 

r 

2 

8 

4 

(HL) 

4 

15 

7.5 

fix  +  d) 

6 

23 

11.5 

(lY  +  d) 

6 

23 

11.5 

Addressing  Mode:    r:  implicit;  (HL):  indirect;  (IX  +  d),  {lY  +  d):  in- 
dexed. 


Byle  Codes: 


RL  r 


r             r:  A 

B 

c 

D 

E 

H 

L 

cbJ  !7 

10 

11 

12 

13 

M 

15 

Flags: 


Example: 


s  z 


H      cgyv  N  c 


• 

• 

0 

• 

.0 

• 

C  is  set  by  bit  7  of  source. 
RL  E 


Before: 


After: 


6£ 


OBJECT  CODE 
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RLA 


Rotate  accumulator  left  through-  carry  flag. 


Function: 


Format: 


Description: 


Data  Flow: 


0     0     0  s 


17 


The  contents  of  the  accumulator  are  shifted  left 
one  bit  position.  The  contents  of  the  carry  flag  are 
moved  into  bit  0  and  the  original  contents  of  bit  7 
are  moved  into  the  carry  flag,  (9  bit  rotation.) 


Timing:  1  M  cycle;  4  T  states;  2  usee  @  2  MHz 

Addressing  Mode:  implicit. 


Flags: 


Example: 


17 


OBJECT  CODE 


s 

z 

H 

p/v 

N 

C 

o 

o 

® 

C  is  set  by  bit  7  of  A. 

RLA 

Before: 


OF 


01 


After: 
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RLCA 


Rotate  accumulator  left  with  br,anch  carry. 


Function: 


J 


Format: 


Description: 


Data  Flow; 


0 

0  j  0 

0 

0 

1 

1 

1 

07 


The  contents  of  the  accumulator  are  rotated  left 
one  bit  position.  The  original  contents  of  bit  7  is 
moved  to  the  carry  flag  as  well  as  to  bit  0. 


Timing:  1  M  cycle;  4  T  states;  2  usee  @  2  MHz 

Addressing  Mode:  Implicit. 


Flags: 


Example: 


07 


OBJECT  CODE 


s 

z 

H 

PA' 

N 

C 

o 

• 

C  is  set  by  bit  7  of  A. 

RLCA 

Before: 


6B 


01 


After: 


Note:  This  instruction  is  identical  to  RLC  A,  ex- 
cept for  the  flags.  It  is  provided  for  compat- 
ibility with  the  8080. 
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RLC  r 

Function: 

Format: 


Description: 


Data  Flow: 


Timing: 


Rotate  register  r  left  with  branch  carry. 


n^7^ — oiJ 


1 

1 

0 

0 

1 

0 

1 

1 

0 

0 

0 

0 

e 

r  1 

byte  2 


The  contents  of  the  specified  register  are  rotated 
left.  The  original  contents  of  bit  7  are  moved  to 
the  carry  flag  as  well  as  bit  0.  r  may  be  any  one  of: 


A  -  HI 
B  -  000 
C  -  001 
D  -  010 


E  -  on 

H  -  100 
L  -  101 


2  M  cycles;  8  T  states;  4  usee  @  2  MHz 


Addressing  Mode:  Implicit 
Byte  Codes:  r 


A 

B 

C 

0 

£ 

H 

L 

CB- 

07 

00 

01 

02 

03 

OA 

05 
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THE  Z80  INSTRUCTION  SET 


s 

2 

H 

N 

C 

• 

o 

o 

C  is  set  by  bit  7  of  source  register. 


Example: 


RLC  B 


CB 


OBJECT  CODE 


Before: 


B  62 


After: 


56 
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RLC  (HL)  Rotate  left  with  branch  carry  memory  location 

(HL). 


Function: 


Format: 


Description: 


(HL) 


1 

1 

0 

0 

1 

0 

( 

1 

0 

0 

0 

0 

0 

1 

1 

0 

byte  1:  CB 
byte  2:  06 


The  contents  of  the  memory  location  addressed  by 
the  contents  of  the  HL  register  pair  are  rotated  left 
one  bit  position  and  the  result  is  stored  back  at 
that  location.  The  contents  of  bit  7  are  moved  to 
the  carry  flag  as  well  as  to  bit  0. 


Data  Flow: 


Timing: 


i'6 

4  M  cycles;  15  T  states;  7,5  usee  @  2  MHz 


Addressing  Mode:  Indirect 
Flags: 


s 

z 

H 

N 

c 

9 

% 

O 

O 

® 

C  is  set  by  bit  7  of  the  memory  location. 
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Example:  RLC  (HL) 


Before: 


After: 


D3  |f 


H  61U  L  H 


6114 


CB 


06 


C5 


61  H 


OBJECT  CODE 
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RLC  (IX  +  d)     Rotate  left  with  branch  carry  memory  location  (IX 
+  d) 


Fttnciwn: 


□ 


Format: 


r 

1 

0 

1 

L 

i 

0 

1 

1 

1 

0 

0 

i 

0 

t  j  i 

-J  J  ,  1  p 

 d  

J  i  !  !  L 


byte  2:  CB 

byte  3:  offset  value 


0 

0 

0  1  0 

0 

1 

1 

0 

0    byte  4:  06 


Descripiion:  The  contents  of  the  memory  location  addressed  by 

the  contents  of  the  IX  register  plus  the  given  offset 
value  are  rotated  left  and  the  result  is  stored  back 
at  that  location.  The  contents  of  bit  7  are  moved 
to  the  carry  flag  as  well  as  to  bit  0. 
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Timing:  6  M  cycles;  23  T  states;  11.5  usee  @  2  MHz 

Addressing  Mode:  Indexed. 


Flags: 


Example: 


s 

z 

H 

©■V 

• 

• 

o 

# 

C  is  set  by  bit  7  of  memory  location. 
RLC    (IX  +  I) 


Before: 


42 


046! 


After: 


04B1 


00 


C6 


01 


OBJECT  CODE 


0-SBl 
0482 


63 


94 


04B1 
04B2 


63 


m 
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RLC  (lY  +  d)     Rotate  left  with  carry  memory  location  (lY  -i-  d). 


Function: 


Format: 


j       l^v^  j  7 


C                     j  5Y  +  d] 

byte  1:  FD 

1 

1 

1 

1    1  ! 

1 

0 

i 

1 

1 

0 

0 

1 

0 

1 

1 

byte  2:  CB 

J  I  I  I  !  L  1- 


byte  3:  offset  value 


0 

0 

0 

0 

0 

1 

! 

0 

0    byte  4:  06 


Description:  The  contents  of  the  memory  location  addressed  by 

the  contents  of  the  lY  register  plus  the  given  offset 
value  are  rotated  left  and  the  result  is  stored  back 
at  the  location.  The  contents  of  bit  7  are  moved  to 
the  carry  flag  as  well  as  bit  0. 
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Tinung:  6  M  cycles;  23  T  states;  1 1.5  usee  @  2  MHz 

Addressing  Mode:  indexed. 


s 

z 

H 

N 

C 

9 

o 

9 

o 

C  is  set  by  bit  7  of  memory  location. 
Example:  RLC    (lY  4-  2) 


Before:  After: 


OBJECT  CODE 
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RhD 


Rotate  left  decimal 


Funclion: 


1 


Format: 


i 

1 

1 

0 

1 

1 

0 

1 

byte  1:  ED 
byte  2:  6F 

0 

1 

1 

Q 

1 

I 

t 

Description:  The  4  low  order  bits  of  the  memory  location  ad- 

dressed by  the  contents  of  HL  are  moved  to  the 
high  order  bit  positions  of  that  same  location.  The 
4  high  order  bits  are  moved  to  the  4  low  order  bits 
of  the  accumulator.  The  low  order  of  the  ac- 
cumulator is  moved  to  the  4  low  order  bits  of  the 
memory  location  originally  specified.  All  of  these 
operations  occur  simultaneously. 


Data  Flow, 


Tinting: 


5  M  cycles;  18  T  states;  9  usee  @  2  MHz 


A  ddressing  Mode:   Ind  i  rec  t . 
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s 

z 

H 

N 

C 

• 

• 

|o 

• 

o 

Examples:  RLD 

Before:  After: 


H  84F2  L  H  r  B4F2  L 


OBJECT  CODE 
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RR  s 


Rotate  right  s  through  carry. 


Function: 


Format: 


(HL) 


(IX  +  d) 


(lY  +  d) 


J  I  I 


i 

0 

a 

I 

0 

1 

! 

a 

0 

0 

t 

i 

1  1 

1  ■  1  ' 

) 

i 

0 

0 

i 

0 

i 

0 

0 

0 

i  j  i 

1 

1 

0 

1 

1 

0 

s 

0 

! 

1 

1 

0 

0 

i 

0 

! 

i 

0 

0 

0 

1 

1 

1 

i 

0 

1 

1 

1 

1 

J 

j 

0 

1 

! 

t 

0 

0 

1 

0 

1 

1 

J  '  '  - 

 1  t  

a 

0 

0 

1 

1 

1 

1 

0 

byte  1:  CB 

byte  2 

byte  J:  CB 

byte  2:  IE 

byte  i:  DD 

byte  2;  CB 

byte  3:  offset  value 

byte  4:  IE 

byte  i :  FD 

byte  2:  CB 

byte  3:  offset  value 

byte  4:  IE 


r  may  be  any  one  of: 


A  -  111 
B  -  000 
C  -  001 
D  -  010 


E  -  on 

H  -  100 
L  -  101 


Description:  The  contents  of  the  location  determined  by  the 

specific  operand  are  shifted  right.  The  contents  of 
the  carry  flag  are  moved  to  bit  7  and  the  contents 
of  bit  0  are  moved  to  the  carry  Hag.  The  final 
result  is  stored  back  in  the  original  location,  s  is 
defined  in  the  description  of  the  similar  RLC  in- 
structions. 
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Da  (a  Flow: 


1 — ^  i 

V 

E                \  ALU 
I  \ 

Timing: 


s: 

M  cycles: 

T stales: 

@  2  MH::; 

F 

2 

8 

4 

(HL) 

4 

!5 

7.5 

(IX  +  d) 

6 

23 

!!.5 

(lY  +  d) 

6 

23 

11.5 

Addressing  Mode:    r;  implicit;  (HLK  indirect;  (IX  +  d),  (lY  +  d):  in- 
dexed. 


Byte  Codes: 


RR  r: 

r: 

A 

B 

C 

D 

£ 

H 

L 

CB. 

IF 

18 

19 

lA 

IB 

IC 

iD 

Flags: 


Example: 


CB 


OBJECT  CODE 


s  z 


P/V    N  C 


• 

o 

• 

C  is  set  by  bit  0  of  source  data. 


RR  H 

Before: 


H  6B 


After: 
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RRA 


Rotate  accumulator  right  through  carry. 


Function: 


Format: 


Description: 


3 — *'[ZJ~^ 


Cf 


Hi     ^     I  I 


IF 


The  contents  of  the  accumulator  are  shifted  right- 
one  bit  position.  The  contents  of  the  carry  flag 
are  moved  to  bit  7  and  the  contents  of  bit  0  are 
moved  to  the  carry  flag  {9-bit  rotation). 


Data  Flow: 


'  ■y-y/./'/f... 

c 

E               \  AtU 

'A 

1  j 

Timing:  1  M  cycle;  4  T  states;  2  usee  @  MHz 

Addressing  Mode:  Implicit. 


Flags: 


Example: 


OBJECT  CODE 


s 

z 

H 

P/V 

N 

C 

o 

o 

9 

Cis  set  by  fait  Oof  A. 

RRA 
Before: 


After: 


Note:  This  mstruction  is  almost  identical  to  RR  A.  It 
!S  provided  for  8080  compatibility. 
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RRC  s 


Rotate  right  with  branch  carry  s. 


Function: 


Format; 


(HL) 
(IX  +  d) 


(lY  +  d) 


3^ 


s:   s  is  any  of  r,  (HL),  (IX  +  d),  (lY  +  d). 


1 

0 

0 

1 

0   j  1    j  1 

byte  1 :  CB 

0 

0 

0 

0 

1 

1  '  ! 

byte  2 

0 

0 

0 

0 

i  j  ( 

( 

0 

1  1  0 

1 

0 

1 

'1' 

0 

'  1° 

( 

( 

1    1    1    ,    (    i  1 

0 

0 

0 

0 

( 

( 

[ 

0 

1 

I 

f 

1 

I 

! 

Q 

1 

1 

1 

0 

0 

1 

0 

1 

1 

^  '!'      1     '1     j"    '  "   '      '  , 

t     1     i  .  r    ,1    1   1 

0  1  0 

0 

0 

i 

1 

( 

0 

byte  i:  CB 

byte  2:  OE 

byte  1:  DD 

byte  2:  CB 

byte  3:  offset  value 

byte  4:  OE 

byte  !:  FD 

byte  2:  CB 

byte  3;  offset  value 

byte  4:  OE 


r  may  be  any  one  of: 


A  -  111 
B  -  000 
C  ~  001 
D  -  010 


E  -  Oil 
H  -  100 
L  -  101 


Description:  The  contents  of  the  location  determined  by  the 

specified  operand  are  rotated  right  and  the  result 
is  stored  back  in  the  original  location.  The  con- 
tents of  bit  0  are  moved  to  the  carry  flag  as  well  as 
to  bit  7.  s  is  defined  in  the  description  of  the 
similar  RLC  instructions. 
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Dala  Flow 


Timing: 


s: 

M  cvdes: 

T stales: 

usee 
@  2  MHz: 

r 

2 

8 

4 

(HL) 

4 

15 

7.5 

(iX  +  d) 

6 

23 

11.5 

(lY  +  d) 

6 

23 

11.5 

Addressing  Mode:    r:  implicit;  (HL):  indirect;  (IX  +  d),  (lY  +  d):  in- 
de.xed. 


Byte  codes: 


Flags: 


Example: 


RRC  r 

r; 

A 

B 

C 

D 

E      H  L 

CB- 

OF 

08  j 

09 

OAjOB  joC  |oDj 

s 

z 

H 

N 

C 

!• 

•  1 

o| 

o|® 

C  is  set  by  bit  0  of  source  data. 
RRC  (HL) 


Before:  After: 


OBJECT  CODE 
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RRCA 


Rotate  accumulator  right  with  branch  carry. 


Function: 


Formal: 


Description: 


Data  Flo  w: 


L  ».o|J^[  j 


1  0 

0 

0  1  0 

i 

,  1  > 

i 

1 

1 

The  contents  of  the  accumulator  are  rotated  right 
one  bit  position.  The  contents  of  bit  0  are  moved 
to  the  carry  flag  as  well  as  to  bil  7, 


Timing:  I  M  cycle;  4  T  stales;  2  usee  @  2  MHz 

Addressing  Mode:  Implicit. 

Flags: 


s 

z 

H 

H 

c 

o 

o 

• 

C  is  set  by  bit  0  of  A, 


Example: 


RRCA 
Before: 


After: 


OF 


OBJECT  CODE 


51  F        A  6A 


40  F 
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RRD 


Rotate  right  decimal. 


Function: 


A    7       4  3  0 


71  r — \ 


Format: 


'  1 '  1 ' 

0 

s 

! 

0  [  0  j  1 

i 

1 

byte  !:  ED 
byte  2:  67 


Description:  The  4  high  order  bits  of  the  memory  location  ad- 

dressed by  the  contents  of  the  HL  register  pair  are 
moved  to  the  low  order  4  bits  of  that  location.  The 
4  low  order  bus  are  moved  10  the  4  low  order  bits 
of  the  accumulator.  The  low  order  bits  of  the  ac- 
cumulator are  moved  to  the  4  high  order  bit  posi- 
tions of  the  memory  location  originally  specified. 
All  of  the  above  operations  occur  simultaneously. 


Data  Flow: 


Timing: 


5  M  cycles;  18  T  states;  9  usee  @  2  MHz 


Addressing  Mode:  Indirect. 
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Flags: 


s 

z 

H 

(P/V 

N  C 

• 

•I 

o 

• 

ot 

Example:  RRD 

Before:  After: 
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V 

■RST  p  Restart  at  p. 


Function: 


(SP  -  1)  -  PChigh!  (SP  -2)-  PCiow;  SP  ^  SP 
~  2;  PChigh  *-  0;  PCiow  P 


Forma!: 


n  r- 

—  p  „ 


Description:  The  contents  of  the  program  counter  are  pushed 

onto  the  stack  as  described  For  the  PUSH  instruc- 
tions. The  specified  value  for  p  is  then  loaded  into 
the  PC  and  the  next  instruction  is  fetched  i'rom 
this  new  address,  p  may  be  any  one  of: 


OOH 

-  000 

20H  - 

100 

08  H 

-  001 

28H  - 

101 

!0H 

-  010 

30H  - 

110 

18H 

-  Oil 

38H  - 

III 

This  instruction  performs  a  jump  to  any  of  eight 
starting  addresses  in  low  memory  and  requires  only 
a  single  byte.  It  may  be  used  as  a  fast  response  to 
an  interrupt. 


Daia  Flow: 


Pel 


IT 


SP  k 


STACK 
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Timing:  3  M  cycles;  1 1  T  states;  5.5  usee  @  2  MHz 

Addressing  Mode:  Indirect. 
Byie  Codes:  i 


00 

08 

10 

18 

20 

28 

30 

38 

CF 

07 

DF 

E7 

EF 

F7 

FF 

Flags: 


s  z 


in 


P/V    N  C 


(no  effect). 


Example: 


RST  38H 


Before: 


PC  I 

spI 


After: 


0269 
026A 

FF 

5! 

BF 

OBJECT  CODE  026B 

03 

0269 
026A 
0268 


03 
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SBC  A,  s 


Subtract  with  borrow  accumulator  and  specified 
operand. 


Funcnon: 
Formal: 


(lY  +  d) 


A  ^  A  -  s  -  C 

s:  may  be  r,  n,  (HL),  (IX  +  d),  or  (lY  +  d) 


r        ?    0    0    I  1 


I      I      0      I      I      I      I  0 


— I — I — ^ — I — , — ^ 


p    1  I  i  I™ 


T  1  1  1  1  1  

 d  

_I  I  I  J  l_l  !- 


"l  s  ! — -i  1  1  r 


_1  I  i  1  1  1  L. 


!•  may  be  any  one  of: 


byte  i:  DE 

byte  2:  immediate 
data 


(HL) 

1 

0 

0 

i 

i 

! 

1 

0 

byie  i:  9E 

(IX +  d) 

0 

1 

i 

1 

0 

1 

byte  1:  DD 

1 

0 

0 

1 

1 

1 

1 

0 

9E 

byte  3:  offset  value 
byte  1:  FD 
byte  2:  9E 
byte  3:  offset  value 


A  -  ill 
B  -  000 
C  -  001 
D  "  OiO 


E  -  Oil 
H  -  100 
L  -  101 


Description: 


The  specified  operand  s,  summed  with  the  con- 
tents of  the  carry  flag,  is  subtracted  from  the  con- 
tents of  the  accumulator,  and  the  result  is  placed 
in  the  accumulator,  s  is  defined  in  the  description 
of  the  similar  ADD  instructions. 
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Dala  Flo  w: 


Timing: 


s: 

M  cycles: 

T states: 

usee 
@  2  MHz: 

r 

1 

4 

1 

n 

2 

7 

3.5 

(HL) 

7 

3.5 

(IX  +  d) 

5 

19 

9.5 

(lY  +  d) 

5 

19 

9.5 

Addressing  Mode:    r:  implicit;  n:  immediate;  (HL):  indirect;  (IX  + 
d),  (iY  +  d):  indexed. 


Byte  Codes: 


Flags: 


SBC    A,  r 

r:  A 

B 

C 

D 

E 

H 

L 

9F 

98 

99 

9A 

9B 

9C 

9D 

S     Z  H 

P/S>  N 

C 

• 

• 

• 

• 

( 

• 

Example: 


SBC  A,  (HL) 
Before: 


After: 


B2 


51 


3600 


3600 


9E 


3600 


OF 


3600 


OF 


OBJECT  CODE 
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SBC     HL,  SS      Subtract  with  borrow  HL  and  register  pair  ss. 


Function: 
Forma!: 


Description: 


Data  Flow: 


HL  ^  HL 


ss 


C 


1 

J 

! 

0 

i 

1 

0 

i 

0 

I 

I 

s  s 

1 

0 

0 

1 

0 

byte  2 


The  consents  of  the  specified  register  pair  plus  the 
contents  of  the  carry  Hag  are  subtracted  from  the 
contents  of  the  HL  register  pair  and  the  result  is 
stored  back  in  HL.  ss  may  be  any  one  of: 


BC  -  00 
DE  -  01 


HL 
SP 


10 
11 


Timing:  4  M  cycles;  15  T  stales;  7.5  usee  @  2  MHz 

Addressing  Mode:  Impiicit. 
Byte  Codes:       ss;    bc  de  hi  sp 

ED-    42  (52    62  72 
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Flags: 


S     Z   H  N  C 


H  is  set  if  borrow  from  bit  12. 
Cis  set  if  borrow. 


Example: 


SBC   HL,  DE 


Before: 


After: 


ED 


52 


OBJECf 
CODE 


66 


0689 


3142 
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SCF 


Set  carry  flag. 


Function: 


C  -  1 


Formal: 


0    0    !    s    0    ;    I     !  37 


Descnptio/i:  The  carry  flag  is  set. 

Timing:  1  M  cycle;  4  T  states;  2  usee  @  2  MHz 

Addressmg  Mode:  Implicit. 
Flags: 


5 

Z 

H 

P/V 

N 

c 

o 

o 

1 
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SET  b,s 

Function: 
Format: 


Set  bit  b  of  operand  s 
Sb  *-  J 


(HL) 


(IX  +  d) 


(lY  +  d) 


1 

1 

0 

0 

1 

0 

1 

1 

( 

i 

i  I 

 r  ! 

0 

0 

1 

0  j  1   j  1 

! 

! 

1  1 

1 

0 

( 

0 

1 

1 

1  1  0 

i 

1 

,  0 

0 

1 

0  j  (   j  1 

n  i  r  1  \  r 


J  L 


J  L 


J  L 


_^  J  j  1  j- 

-d- 


J  I  \  I 


byte  I :  CB 
byte  2 
byte  1:  CB 
byte  2 
byte  1:  DD 
byte  2:  CB 
byte  3:  offset  value 
byte  4 

byte  1:  FD 
byte  2:  CB 
byte  3;  offset  value 
byte  4 


r  may  be  any  one  of; 

A  -  ill 

B  -  000 

C  -  DDI 

D  -  010 

b  may  be  any  one  of: 

0  -  000 

1  -  001 

2  -  010 
3-011 


E 
H 
L 


4 
5 
6 
7 


Oil 
100 
101 


100 
101 

no 
111 


Description:  The  specified  bit  of  the  location  determined  by  s  is 

set.  s  IS  defined  in  the  description  of  the  similar 
BIT  instructions. 
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Data  Flow: 


Timing: 


s: 

M  cycles: 

T slates: 

usee 
@  2  MHz: 

r 

2 

8 

4 

(HL) 

4 

15 

7.5 

(IX  +  d) 

6 

23 

11.5 

(lY  +  d) 

6 

23 

II. 5 

Addressing  Mode:    r:  implicit;  (HL):  indirect;  (IX  +  d),  (lY  +  d):  in- 
dexed. 


Byte  Codes: 


SET    b,  r 


CB- 


SET    b,  (HL) 
SET   b,  (IX  +  d) 
SET    b,  (lY  +  d) 


b;  '••  A 

B 

C 

D 

E 

H 

L 

0 

C7 

CO 

Ci 

C2 

C3 

C4 

C5 

1 

CF 

C8 

C9 

CA 

CB 

CC 

CO 

2 

D7 

DO 

DS 

D2 

D3 

04 

05 

3 

DF 

Da 

D9 

DA 

DB 

DC 

DO 

4 

E7 

EO 

El 

E2 

E3 

E4 

E5 

5 

EF 

EB 

E9 

EA 

EB 

EC 

ED 

6 

 1 

F7 

FO 

F1 

F2 

F3 

F4 

F5 

7 

FF 

F8 

F9 

FA 

FB 

FC 

FO 

b: 

0 

I 

2 

4 

5 

6 

7 

C6 

CE 

D6 

DE 

E6 

EE 

F6 

FE  j 
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Flags: 


5     z  H        P/V  N  c 


(no  effect) 


Example: 


SET    7,  A 


CB 


OBJECT  CODE 


Before: 

A  I  61 


After: 
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SLA  S  Arithmetic  shift  left  operand  s. 


Function: 
Format: 


(HL) 
(IX  +  d) 


(lY  +  d) 


c 


! 

a  1  0 

! 

0 

0 

0  j  1  I  0 

0 

1  r 
 1.  1  

1 

! 

0 

0 

! 

0 

I 

! 

0 

0 

1      0  0 

1 

1 

0 

1 

1 

oh 

i 

i 

0  1  I 

i 

1 

0 

0 

1 

0 

1 

\ 

0 

0 

1 

0 

o), 

,|o 

! 

i 

1 

! 

0 

1 

( 

1 

0 

0 

1 

0 

1 

i 

I     I     1  I 


0 

0 

1 

0 

0 

) 

1 

0 

byte  1 ;  CB 
byte  2 
byte  i :  CB 
byte  2:  26 
byte  1:  DD 
byte  2:  CB 
byte  3:  offset  value 
byte  4:  26 
byte  i:  FD 
byte  2:  CB 
^    byte  3;  offset  value 
byte  4:  26 


r  may  be  any  one  of: 

A  -  111  E  -  Oil 

B  -  000  H  "  100 

C  -  001  L  -  101 

D  -  010 

Description:  The  contents  of  the  location  determined  by  the 

specific  operand  are  arithmetically  shifted  left  with 
the  contents  of  bit  7  being  moved  to  the  carry  flag 
and  a  0  being  forced  into  bit  0.  The  final  result  is 
stored  back  in  the  original  location,  s  is  defined  in 
the  description  of  the  similar  RLC  instructions. 
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Tiiiimg: 


usee 

S' 

M  cvties: 

T  slates: 

@  2  MHz: 

r 

a 

■ 

4 

(HLf 

4 

15 

7.5 

{IX  +  d) 

6 

23 

11. 5 

(lY  +  d) 

6 

23 

I IJ 

Addressing  Mode:    r:  implicit;  (HL):  indircci;  (IX  +  d),  (lY  +  d):  in- 
dexed. 


Bvie  Codes: 


SLA  r 


A     B__^  _C_    D_  E  H 
Cb|~27"|~20  I  21  \^72  \72\2i]  25 


Flags: 


Example: 


C  IS  set  by  bit  7  of  source  data. 
SLA  (HLi 

Before:  After; 


0FF2 


0FF2 


OBJECT  CODE 
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SRA  s 


Shift  right  arithmetic  s. 


Function: 


1 — ZJ      ?  r 


Format: 


(HL) 
(IX  +  d) 


! 

i 

0 

0  j  1 

0 

( 

1 

byte  i:  CB 

0 

0 

'  1  ° 

t 

1  1 

^  ■ 

byte  2 

1 

1 

0 

(loji 

1 

byte  1:  CB 

0 

ol  , 

0 

1 

1 

1 

0 

byte  2:  2E 

"I — i — r 


(lY  +  d) 


0 

i 

0 

1 

r 

1  0 

1 

1 

1 

( 

1 

t 

0 

1 

0 

1 

0 

t 

1 

~!  1  r — T — T  i  r 

I     I     i     I     I     I  I 


[IK 


0 

1 

0 

1 

1  1  i 

0 

byte  1:  DD 
byte  2:  CB 
byte  3:  offset  value 
byte  4:  2E 
byte  1:  FD 
byte  2;  CB 
-■"j  byte  3:  offset  value 
byte  4:  2E 


Description: 


r  may  be  any  one  of: 

A  -  111  E  -  on 

B  -  000  H  -  100 

C  -  001  L  -  101 

D  -  010 

The  contents  of  the  location  determined  by  the 
specific  operand  are  arithmetically  shifted  right. 
The  contents  of  bit  0  are  moved  to  the  carry  flag 
and  the  contents  of  bit  7  remain  unchanged.  The 
final  result  is  stored  at  the  original  iocation.  s  is 
defined  m  the  description  of  the  similar  RLC  in- 
structions. 
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Data  Flow 


Timing: 




s: 

M  cvdes: 

7"  stales: 

usee 
@  2  MHz: 

r 

2 

8 

4 

(HL) 

4 

15 

7.5 

(IX  +  d) 

6 

23 

n.5 

(lY  +  d) 

6 

23 

11.5 

Addressing  Mode:    r:  impiica;  (HL):  indirect;  (iX  +  d),  (lY  +  d):  in- 
dexed. 


Byie  Codes: 


SRA    r         ^   s    c   d  _  e  H_,...t 


CB-  2F 


28  I  2?  I  2A 1  26  |  2C  j  2D 


S      Z  H        ®'\'    N  C 


o 


o 


C  is  set  by  bit  0  of  source  data. 


Example:  SRA  A 

Before:  After: 


OBJECT  CODE 
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SRL  S  Logical  shift  right  s. 


Function: 


Formal: 


(HL) 
(IX  +  d) 


(lY  + 


I 

i 

0  [  0 

t  j  0  j  1   j  1 

0 

0 

^  j  p  ^" 

1  '  1 

r 

1 

0 

0 

1 

0 

0 

i 

! 

0 

1 

J 

0  1  i 

1 

! 

0 

1 

1 

1 

0 

0 

1 

0 

1 

1 

J  L 


1 

1 

0 

0 

1 

0 

i 

— J — J — J_ 

"d  - 


_L_i  I  1  [  1_ 


byte  1 :  CB 

byte  2 

byte  1:  CB 

byte  2;  3E 

byte  t:  DD 

byte  2:  CB 

byte  3:  offset  value 

byte  4:  3E 

byte  1:  FD 

byte  2:  CB 

byte  3:  offset  value 

byte  4:  3E 


r  may  be  any  one  of: 


A  -  HI 

B  -  000 

C  -  001 

D  -  010 


E  -  01! 
H  -  100 
L  -  101 


Description:  The  contents  of  the  location  determined  by  the 

specific  operand  are  logically  shifted  right.  A  zero 
IS  moved  into  bit  7  and  the  contents  of  fait  0  are 
moved  into  the  carry  flag.  The  final  result  is  stored 
back  in  the  original  location. 
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Data  Flow. 

A 


Timing: 


s: 

M  cvdes: 

T Slates: 

usee 
@  2  MHz: 

r 

8 

4 

(HLi 

4 

15 

7.5 

{IX  +  d) 

6 

23 

ii.5 

(!Y  +  d) 

6 

23 

I  I.S 

Addressing  Mode:    r:  implicii;  (HL):  mdirecK  (IX  +  d),  (lY  +  d):  in- 
dexed. 


Bvie  Codes: 


SRL  r 


A 

s 

C 

D 

E 

H 

L 

3B 

39 

3A 

3B 

3C 

3D 

Flags: 


Example: 


s  z 


©'V   N  c 


• 

• 

• 

o 

• 

C  is  set  by  bit  0  of  source  data. 
SRL  E 

Before:  After: 


01  ]f 
"oi  Ie 


OBJECT  CODE 
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SUB  s        Subtract  operand  s  from  accumulator. 


Function: 
Formal: 


(HL) 
(IX  +  d) 


(lY  +  d) 


A  *-  A  -  s 

s:  may  be  r,  n,  (HL),  (IX  -f  d)  or  (lY  +  d) 


10     0  10 


T  1  1  1  [- 

 n  


-J  1  I  I  I  1  L_ 


I  0 


i 

i 

0 

i 

i 

i 

0 

1 

1 

0 

0 

i 

0 

1 

i 

0 

J  1_ 


J  I  1  i_ 


i 

i 

I 

i 

0 

( 

1 

0 

a 

1 

0 

f 

0 

_l  1  1- 


-J  I  !  I  I  I  L. 


byte  1:  D6 

byte  2:  immediate 
data 

96 

byte  1:  DD 

byte  2:  96 

byte  3:  offset  value 

byte  i:  FD 

byte  2:  96 

byte  3:  offset  value 


r  may  be  any  one  of; 


A  -  111 
B  -  000 
C  -  DDI 
D  -  GIG 


E  -  on 

H  -  100 
L  -  101 


Description: 


The  specified  operand  s  is  subtracted  from  the  ac- 
cumulator and  the  result  is  stored  in  the  ac- 
cumulator. The  operand  s  is  defined  in  the 
description  of  the  similar  ADD  instructions. 
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Dala  Flow: 


Timing: 


s: 

M  cycles: 

T  states: 

r 

1 

4 

n 

2 

7 

3.5 

(HL) 

7 

3.5 

{IX  +  d) 

5 

19 

9.5 

{IX  +  d) 

5 

!9 

9.5 

Addressing  Mode:    r:  implicit;  n:  immediate;  {HL):  indirect;  {IX  + 
d),  (lY  +  d):  indexed 


Byte  Codes: 
Flags: 


SUB  r 


s  1 


B 

C 

0 

£ 

H 

L 

K) 

91 

92 

93 

94 

95 

Example: 


SUB  B 
Before: 


After: 


90 


BO 


OBJECT  CODE 
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XOR  S 


Exclusive  or  accumulator  and  s. 


Function: 
Formal: 


(HL) 
(IX  +  d) 


(lY  +  d) 


A  A^s 

s:  may  be  r,  n,  (HL),  (IX  +  d),  or  (lY  +  d) 


— I — I — I — 


_J  1  I  I  :  1  L. 


i 

0 

s 

0 

( 

! 

0 

( 

0 

1 

1 

1 

0 

1 

! 

0 

1 

0 

1 

i 

1 

0 

n  \  1  1  1  1  r 

 d  

_1  I  !  I  i  I  L_ 


1 

0 

1 

0 

1 

1 

1 

0 

-^  1  1  !  J  1  r- 

 d  

™i  I™  1  1  1  i  L. 


byte  i:  EE 

byte  2:  immediate 
data 

AE 

byte  1:  DD 

byte  2:  AE 

byte  3;  offset  value 

byte  i :  FD 

byte  2:  AE 

byte  3:  offset  value 


r  may  be  any  one  of: 


A  -  111 

B  -  000 

C  -  001 

D  -  010 


E  -  Oil 
H  -  100 
L  -  101 


Description:  The  accumulator  and  the  specified  operand  s  are 

exclusive  'or'ed,  and  the  result  is  stored  in  the  ac- 
cumulator, s  IS  defined  in  the  description  of  the 
similar  ADD  instructions. 
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Date  Flow: 


Timing: 


usee 

s: 

M  cycles: 

T stales: 

@  2  MHz: 

r 

i 

4 

2 

n 

2 

7 

3.5 

(HL) 

2 

7 

3.5 

(IX  +  d) 

5 

19 

9.5 

(lY  +  d) 

5 

19 

9.5 

Addressing  Modes:  r:  implicit;  n:  immediate;  (HL):  indirect;  (IX  + 
d),  (lY  +  d);  indexed 


Byle  Codes: 


Flags: 


XOR  r 


H  I 


s 

z 

H 

N 

r 

• 

• 

o 

• 

o 

0 

AF 

Aa 

A9 

AA 

AB 

AC 

AD 

Example: 


XOR  BIH 


Before; 


After: 


EE 


Bl 


OBJEaCODE 


A  3a 
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INTRODUCTION 

This  chapter  will  preseni  the  general  theory  of  addressing  and  the 
various  techniques  which  have  been  developed  to  facilitate  the  retrieval 
of  data.  In  a  second  section,  the  specific  addressing  modes  available  in 
the  Z80  will  be  reviewed,  along  wish  their  advantages  and  limitations. 
Finally,  in  order  to  familiarize  the  reader  with  the  various  irade-offs 
possible,  an  applications  section  will  demonsirale  possible  irade-orfs 
between  the  various  addressing  techniques  by  studying  specific  applica- 
tion programs. 

Because  the  Z80  has  several  16-bst  registers,  in  addition  lo  the  pro- 
gram counter,  which  can  be  used  to  specify  an  address,  it  is  important 
that  the  Z80  user  understand  the  various  addressing  modes,  and  in  par- 
ticular, the  use  of  the  index  registers.  Complex  retrieval  modes  may  be 
omiiied  ai  the  beginning  stage.  However,  all  the  addressing  modes  are 
useful  m  developing  programs  for  this  microprocessor.  Let  us  now 
study  the  various  aiiernalives  available. 

POSSIBLE  ADDRESSING  MODES 

Addressing  refers  to  the  specification,  wuhm  an  instruction,  of  the 
location  of  the  operand  on  which  the  instruction  will  operate.  The  mam 
addressing  methods  will  now  be  examined.  They  are  all  illustrated  in 
Figure  5,1. 

implicit  Addressing  (or  'implied/'  or  "Register") 

Instructions  which  operate  exclusively  on  registers  normally  use  nn- 
plicii  addressing.  This  is  illustrated  in  Figure  5.1,  An  implicit  instruc- 
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tton  derives  Us  name  from  the  fact  that  it  does  not  specifically  contain 
the  address  of  the  operand  on  which  it  operates.  Instead,  its  opcode 
specifies  one  or  more  registers,  usually  the  accumulator,  or  else  any 
other  register(s).  Since  internal  registers  are  usually  few  In  number 
(commo'ily  eight),  this  will  require  a  small  number  of  bits.  As  an  exam- 
ple, three  bits  within  the  instruction  will  point  to  one  out  of  eight  inter- 
nal registers.  Such  instructions  can,  therefore,  normally  be  encoded 
within  eight  bits. This  is  an  important  advantage,  since  an  eight-bit  in- 
struction normally  executes  faster  than  any  two-  or  ihree-byte  instruc- 
tion. 

An  example  of  an  implicit  instruction  is: 
LD  A,  B 

which  specifies  "transfer  the  contents  of  B  into  A"  (Load  A  from  B.) 
Immediate  Addressing 

Immediate  addressing  is  illustrated  in  Figure  5.1.  The  eight-bit  op- 
code is  followed  by  an  8-  or  16-bit  literal  (a  constant).  This  type  of 
instruction  is  needed,  for  example,  to  load  an  eight-bit  value  in  an 
eight-bit  register.  Since  the  microprocessor  is  equipped  with  16-bit  reg- 
isters, li  may  also  be  necessary  to  load  i6-bit  literals.  An  example  of  an 
immediate  instruction  is: 

ADD  A.  OH 

The  second  word  of  this  instruction  contains  the  literal  "0",  which  is 
added  to  the  accumulator. 

Absolute  Addressing 

Absolute  addressing  usually  refers  to  the  way  in  which  data  is  retrieved 
from  or  placed  m  memory,  m  which  an  opcode  is  followed  by  a  i6-bit 
address.  Absolute  addressing,  therefore,  requires  three-byte  instruc- 
tions. An  example  of  absolute  addressing  is: 

LD  {1234H),  A 

U  specifies  that  the  contents  of  the  accumulator  are  to  be  stored  at 
memory  location  "1234"  hexadecimal. 

The  disadvantage  of  absolute  addressing  is  to  require  a  three-byte  in- 
struction. In  order  to  improve  the  efficiency  of  the  microprocessor, 
another  addressing  mode  may  be  made  available,  whereby  only  one 
word  is  used  for  the  address:  direct  addressing. 
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IMPLICIT/IWPLIEO 


OPCODE A 


!  R 


IMMEDIATE 


OPCODE 


LITERAL 


LITERAL  I 
 J 


EXTENDED/ABSOLUTE 


OPCODE 


FULL  16-BIT 
ADDRESS 


DIRECT/SHORT 


OPCODE 


SHORT  ADDRESS 


 ^ 

,  OPCODE  i 


INDEXED 


I 

1  


OPCODE 


XREG 


DISPLACEAAENT 


OR  ADDRESS 


Fig.  5.1:  Basic  Addressing  Modes 
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Direct  Addressing  (or  "Short,"  or  "Relative") 

In  this  addressing  mode,  the  opcode  is  followed  by  an  eight-bit  ad- 
dress. This  is  also  illustrated  in  Figure  5.1.  The  advantage  of  this  ap- 
proach IS  to  require  only  two  bytes  instead  of  three  for  absolute  ad- 
dressing. The  disadvantage  is  to  limit  ail  addressing  withm  this  mode  to 
addresses  0  to  255  or  else  -  128  to  +  127.  When  using  0  to  255  ("page 
zero"),  this  is  also  called  short  addressing,  or  0-page  addressing.  When- 
ever short  addressing  is  available,  absolute  addressing  is  often  called  ev- 
teiided  addressing  by  contrast.  The  range  -  128  to  -i- 127  is  used  with 
branch  instructions.  This  is  called  relative  addressing. 

Relative  Addressing 

Normal  jump  or  branch  instructions  require  eight  bits  for  the  op- 
code, plus  the  16-bit  address  to  which  the  program  has  to  jump.  Just  as 
in  the  preceding  example,  this  mode  has  the  disadvantage  of  requiring 
three  words,  i.e.,  three  memory  cycles.  To  provide  more  efficient 
branching,  relative  addressing  uses  only  a  two-word  format.  The  first 
word  is  the  branch  specification,  usually  along  with  the  test  it  is  imple- 
menting. The  second  word  is  a  displacement.  Since  the  displacement 
must  be  positive  or  negative,  a  relative  branching  instruction  allows  a 
branch  forward  to  127  locations  (seven-bits)  or  a  branch  backwards  to 
128  locations  (usually  +  129  or  - 126,  since  PC  will  have  been  mere- 
cremented  by  2),  Because  most  loops  tend  to  be  short,  relative  branch- 
ing can  be  used  most  of  the  time  and  results  in  significantly  improved 
performance  for  such  short  routines.  As  an  example,  we  have  already 
used  the  instruction  JR  NC,  which  specifies  a  "jump  if  no  carry"  to  a 
location  within  127  words  of  the  branch  instruction  (more  precisely 
-f- 129  to  -  126). 

The  two  advantages  of  relative  addressing  are  improved  performance 
(fewer  bytes  used)  and  program  relocatability  (independence  from  ab- 
solute addresses). 

Indexed  Addressing 

Indexed  addressing  is  a  technique  used  to  access  the  elements  of  a 
block  or  of  a  table  successively.  This  will  be  illustrated  by  examples 
later  in  this  chapter.  The  principle  of  indexed  addressing  is  that  the  in- 
struction specifies  both  an  index  register  and  an  address.  The  contents 
of  the  register  are  added  to  the  address  to  provide  the  final  address.  In 
this  way,  the  address  could  be  the  beginning  of  a  table  in  the  memory. 
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The  index  register  would  then  be  used  lo  access  all  the  elements  of  a 
table  successively  in  an  efficient  way.  (This  requires  the  availability  of 
increment/decrement  instructions  for  the  index  register).  In  practice, 
restrictions  often  exist  which  may  limit  the  size  of  the  index  register,  or 
the  size  of  the  address  or  displacement  field. 


BASE 


diaplacemtsni 


INDEX  REGISTER 


BASE 

s 


MEMORY 


Fig.  5.2;  Addressing  (Pre-indexing) 


Pre-lndexing  and  Post-Indexing 

Two  modes  of  indexing  may  be  distinguished.  Pre-indexing  is  the 
usual  indexing  mode  in  which  the  final  address  is  the  sum  of  a  displace- 
ment or  address  and  of  the  contents  of  the  index  register.  U  is  shown  in 
Figure  5.2,  assuming  an  8-bit  displacement  field  and  a  16-bit  index 
register. 

Post-indexing  treats  the  contents  of  the  displacement  field  like  the 
address  of  the  actual  displacement,  rather  than  the  displacement  itself. 
This  is  illustrated  in  Figure  5.3.  In  post-indexing,  the  final  address  is  the 
sum  of  the  contents  of  the  index  register  plus  the  contents  of  the  mem- 
ory word  designated  by  the  displacement  field.  This  feature  utilizes,  in 
fact,  a  combination  of  indirect  addressing  and  pre-mdexing.  But  we 
have  not  defined  indirect  addressing  yet.  Lei  us  do  that. 
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PQIfJI!S=fiASE 


Y  (inde 


N 


ADOBISS 


Fig.  5.3:  Indirect  Indexed  Addressing  (Post-Indexing) 


Indirect  Addressing 

We  have  already  seen  that  two  subroutines  may  wish  to  exchange  a 
large  quantity  of  data  stored  in  the  memory.  More  generally,  several 
programs,  or  several  subroutines,  may  need  to  access  a  common  block 
of  information.  To  preserve  the  generality  of  the  program,  it  is  desira- 
ble not  to  keep  such  a  block  at  a  fixed  memory  location.  In  particular, 
the  size  of  this  block  might  grow  or  shrink  dynamically,  and  it  may 
have  to  reside  in  various  areas  of  the  memory,  depending  on  its  size.  It 
would,  therefore,  be  impractical  to  try  to  access  this  block  using  abso- 
lute addresses,  that  is  without  rewriting  the  program  every  time. 

The  solution  to  this  problem  lies  in  depositing  the  starting  address  of 
the  block  at  a  fixed  memory  location.  This  is  analogous  to  a  situation  m 
which  several  persons  need  to  get  into  a  house,  and  only  one  key  exists. 
By  convention,  the  key  to  the  house  will  be  hidden  under  the  mat.  Every 
user  will  then  know  where  to  look  (under  the  mat)  to  find  the  key  to  the 
house  (or,  perhaps,  to  find  the  address  of  the  scheduled  meeting,  to 
propose  a  stricter  analogy).  Indirect  addressing,  therefore,  normally 


443 


PROGRAMMtNG  THE  Z80 


uses  an  opcode  followed  by  a  16-bit  address.  This  address  is  used  to 
retrieve  a  word  from  the  memory.  Usually,  it  will  be  a  16- bit  word  (in 
our  case,  two  bytes)  within  the  memory  since  it  is  an  address.  This  is  il- 
lustrated by  Figure  5.4.  The  two  bytes  at  the  specified  address  Al  con- 
tain "A2".  A2  is  then  interpreted  as  the  actual  address  of  the  data  that 
one  wishes  to  access. 


INSTRUCTION  MEMORY 


OPCODE 

(A,) 

INDIRECT 

FSNAL 

ADDRESS  A. 

ADDRESS  (A:) 

A, 

DATA 

Fig.  5.4;  Indirect  Addressing 

Indirect  addressing  is  particularly  useful  any  iime  lhat  pointers  are 
used.  Various  areas  of  the  program  can  then  refer  to  these  pointers  to 
access  a  word  or  a  block  of  data  conveniently  and  elegantly.  The  final 
address  may  also  be  obtained  by  pomting  within  the  instruction  to  a 
16-bit  register  in  which  it  is  contained.  This  is  called  "register  indirect." 

Combinations  of  Modes 

The  above  addressing  modes  may  be  combined.  !n  particular,  it 
should  be  possible  in  a  completely  genera!  addressing  scheme  to  use 
many  levels  of  indirection.  The  address  A2  could  be  interpreted  as  an 
indirect  address  again,  and  so  on. 

Indexed  addressing  can  also  be  combined  with  indirect  access.  This 
allows  the  efficient  access  to  word  n  of  a  block  of  data,  provided  one 
knows  where  the  pointer  to  the  starting  address  is  (see  figure  5.2). 
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We  have  now  become  familiar  wiiii  all  usual  addressing  modes  that 
can  be  provided  m  a  sysiem.  Most  microprocessor  systems,  because  of 
the  limitation  on  the  complexity  of  an  MPU,  which  must  be  realized 
wiihm  a  smgle  chip,  do  not  provide  all  possible  modes  but  only  a  small 
subset  of  these.  The  Z80  provides  a  good  subset  of  possibilities.  Let  us 
examine  them  now. 

Z80  ADDRESSING  MODES 
Implied  Addressing  (Z80) 

Implied  addressing  is  essentially  used  by  smgie-byte  instructions 
which  operate  on  internal  registers.  Whenever  implicit  instructions 
operate  exclusively  on  internal  registers,  they  require  only  one  machine 
cycle  to  execute. 

E.xamples  of  instructions  using  implied  (or  "register")  addressing 
are:  LD  r,r';  ADD  A,r;  ADC  A,s;  SUB  s;  SBC  A,s;  AND  s;  ORs; 
XOR  s;  CPs;  INCr. 

Zilog  further  distinguishes  between  "register  addressing"  and  "im- 
plied addressmg."  Implied  addressing  is  then  limited,  in  that  definition, 
to  instructions  that  do  not  have  a  specific  field  to  point  to  an  internal 
register.  This  introduces  one  more  addressing  mode.  This  is  one  reason 
why  the  number  of  addressing  modes  is  insufficient  to  characterize  the 
capabilities  of  a  microprocessor. 

Immediate  Addressing  (Z80) 

Since  the  Z80  has  both  single-length  registers  {eight  biisj,  and  double- 
length  register  pairs  (16  bits;,  it  provides  two  types  of  immediate  ad- 
dressing, both  with  8-bit  and  16-bit  literals,  instructions  are  then 
either  two  or  three  bytes  long.  The  second  (and  sometimes  the  third) 
byte  contains  the  opcode,  followed  by  the  constant,  or  literal,  to  be 
loaded  in  a  register  or  used  for  an  operation.  Exceptions  are  LD  IX  and 
LD  lY,  which  require  16- bit  opcodes. 

Examples  of  instructions  using  the  immediate  addressing  mode  are: 

LD  r,n  (two  bytes) 
LD  dd.nn  (three  bytes) 

and 

ADD  A,n  (two  bytes) 

When  the  literal  is  two  bytes  long,  the  mode  is  called  "immediate  ex- 
tended," in  the  case  of  the  Z80. 
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Absolute  or  "Extended"  Addressing  (Z80) 

By  definition,  absolute  addressing  requires  three  bytes.  The  first  byte 
is  the  opcode  and  the  next  two  bytes  are  the  16-bit  address  specifying 
the  memory  location  (the  "absolute  address"). 

By  contrast  with  "short  addressing"  (eight-bu  address),  this  mode  is 
also  called  "extended  addressing." 

Examples  of  instructions  using  extended  addressing  are: 

LD  HL,  (nn)  and  JP  nn 

where  nn  represents  the  16-bit  memory  address,  and  (nn)  represents  the 
contents  of  the  specified  location. 

Modified  Zero-Page  Addressing  (Z80) 

Zero-page  addressing  is  not  available  in  the  Z80.  except  through  the 
RST  instruction.  The  special  addressing  mode  used  by  this  instruction 
is  called  "modified  zero-page  addresing." 

The  RST  instruction  contains  a  3-bit  field  in  bit  position  b,  us- 
ed to  pint  to  one  of  8  locations  in  page  0  memory.  The  effective 
address  is  b5b4b3000  and  is  loaded  into  PC.  Since  it  requires  only  a 
single  byte,  this  instruction  executes  rapidly,  and  is  easily  generated  in 
hardware.  It  was  generally  used  to  respond  to  multiple  interrupts  (up  to 
8.)  Its  disadvantage  is  either  to  limit  the  execution  sequence  to  8  loca- 
tions, or  to  require  a  jump  eliminating  the  speed  advantage.  This  is 
because  each  of  the  8  branch  addresses  are  8-bytes  apart. 


Relative  Addressing  (Z80) 

By  definition,  relative  addressing  requires  two  bytes.  The  first  one  is 
the  "jump  relative"  opcode,  whereas  the  second  one  specifies  the  dis- 
placement and  Its  sign. 

In  order  to  differentiate  this  mode  from  the  absolute  jump  instruc- 
tion, it  is  labeled  "JR" 

From  a  timing  standpoint,  this  instruction  should  be  examined  with 
caution.  Whenever  a  test  fails,  i.e.,  whenever  there  is  no  branch,  this  in- 
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strucison  requires  only  seven  "T  cycles."  This  is  because  the  next 
msiruclion  to  oe  executed  is  already  pointed  to  by  the  program  counter. 

However,  when  the  test  succeeds,  i.e.,  whenever  the  jump  takes 
place,  this  instruction  requires  12  "T-states";  a  new  effective  address 
must  be  computed  and  loaded  into  the  program  counter. 

When  computing  the  duration  of  the  execution  of  a  program  seg- 
ment, caution  must  be  exercised.  Whenever  one  is  not  sure  whether  or 
not  the  jump  will  succeed,  one  must  take  into  consideration  the  fact 
that  sometimes  the  jump  will  require  12  T-states.  (condition  met}, 
sometimes  7  (condition  not  met). 

When  designing  a  loop,  execution  will,  therefore,  be  faster  using  a 
JR(Jump  Relative)  testing  a  condition  usually  not  met,  such  as  a  non- 
zero conditson  for  the  counter. 

When  JR's  are  used  outside  of  loops,  and  the  condition  under  test  is 
unknown,  an  average  timing  value  is  often  used  for  the  duration 
of  JR. 

This  timing  problem  does  not  apply  to  the  unconditional  jump  JR  e.  It 
does  not  test  any  condition,  and  always  lasts  12  T-states. 

Indexed  Addressing  (Z80) 

This  addressing  mode  did  not  exist  in  the  8080,  and  was  added  to  the 
Z80  (as  well  as  the  two  index  registers).  As  a  result,  it  became  necessary 
to  add  an  extra  byte  to  the  opcode,  making  it  a  i6-bit  opcode  in  the  Z80 
instruction  set  (LDIR  is  another  example  of  a  16-bit  opcode!.  The 
structure  of  an  indexed  instruction  is  shown  on  Figure  5.5. 


OPCODE 


OPCOOE 


DISPLACEMENT 


BYTE  1 


BYTE  2 


BYTEO 


I                LITERAL  I    BYTE  4 
 ( 


Fig.  5.5;  Indexed  Addressing  Has  2-bytc  Opcode 
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Instructions  allowing  indexed  addressing  are: 

LD,  ADD,  INC,  RLC,  BIT,  SET,  CP.  and  others. 

This  mode  will  be  used  extensively  in  the  programs  operating  on 
blocks  of  data,  tables  or  lists. 

indirect  Addressing  (Z80) 

The  Z80  provides  a  limited  indirect  addressing  capability  called 
"Register  Indirect  Addressing."  !n  this  mode,  each  of  the  16-bit  regis- 
ter pairs  BC,  DE,  HL  may  be  used  as  a  memory  address. 

Whenever  they  pomt  to  16-bit  data,  they  point  to  the  lower  part.  The 
higher  part  resides  at  the  next  (higher)  sequential  address. 

Combinations  of  iVIodes 

Combinations  of  modes  are  essentially  non-existent,  except  that  in- 
structions referring  to  two  operands  may  use  a  different  type  of  ad- 
dressing for  each. 

Thus,  a  load  or  an  arithmetic  instruction  may  access  one  operand  in 
the  immediate  mode,  and  the  other  one  through  an  indexed  access. 

Also,  the  bit  addressing  mechanism  may  access  the  eight-bit  byte 
through  one  of  the  three  addressing  modes,  as  explained  in  the  follow- 
ing paragraph.  The  specific  addressing  modes  available  for  each  in- 
struction are  indicated  in  the  tables  of  the  preceding  chapter. 


Bit  Addressing 

Bit  addressing  is  generally  not  considered  an  addressing  mode  if  ad- 
dressing is  defined  as  accessing  a  byte.  However,  whether  defined  as  a 
mode  or  a  group  of  instructions,  it  is  a  valuable  facility.  Since  it  is  de- 
fined as  an  "addressing  mode"  m  Zilog  nomenclature,  it  will  be  so  de- 
scribed here.  It  is  specific  to  the  Z80  and  was  not  provided  on  the  8080. 

Bit  addressing  refers  to  the  access  mechanism  to  specified  bits.  The 
Z80  is  equipped  with  special  instructions  for  setting,  resetting  and  test- 
ing specified  bits  in  a  memory  location  or  a  register.  The  specified  byte 
may  be  accessed  through  one  of  three  addressing  modes:  register,  regis- 
ter-indirect, and  indexed.  Three  bits  are  used  within  the  opcode  to  select 
one  of  eight  bits. 
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USING  THE  Z80  ADDRESSING  MODES 

Long  and  Short  Addressing 

We  have  already  used  relative  jump  instructions  in  various  programs 
that  we  have  developed.  They  are  self-explanatory.  One  interesting 
question  is;  What  can  we  do  if  the  permissible  range  for  branching  is 
not  sufficient  for  our  needs?  On  many  microprocessors,  the  solution  is 
to  use  a  so  called  long  Jump,  This  is  simply  a  jump  to  a  location  which 
contains  an  absolute  or  "long"  jump  specification: 

JRNC,  S  +  3  BRANCH  TO  CURRENT  ADDRESS 

+  3  IF  C  CLEAR 
JP  FAR  OTHERWISE  JUMP  TO  FAR 

(NEXT  INSTRUCTION) 

The  two-line  program  above  will  result  in  branchmg  to  location  FAR 
whenever  the  carry  is  set.  In  the  case  of  the  Z80,  JP  may  be  used  instead 
of  JR  to  test  all  conditions  and  removes  this  problem. 

Use  of  Indexing  for  Sequential  Block  Accesses 

Indexing  is  primarily  used  to  address  successive  locations  within  a 
table.  The  restriction  is  that  the  maximum  length  must  be  less  than  256 
so  that  the  displacement  can  reside  in  an  eight-bit  index  register. 

We  have  learned  to  check  for  a  character.  Now  we  will  search  a  table 
of  100  elements  for  the  presence  of  a  '*'.  The  starting  address  for  this 
table  is  called  BASE.  The  table  has  only  100  elements.  The  program  ap- 
pears below:  (see  flowchart  on  Figure 5.6); 


SEARCH 

LD 

!X,  BASE 

LD 

A. 

LD 

B,  COUNT 

TEST 

CP 

(IX) 

JR 

Z,  FOUND 

INC 

IX 

DEC 

B 

JR 

NZ,  TEST 

NOTFND 


An  improved  program  will  be  presented  below  in  the  section  on 
Block  Transfer,  using  DJ  NZ, 
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INITIAlfZe 
TO  ELEMENT  0 

□z 

READ  NEXT 
ELEMENT 


POINT  TO 
NEXT  ELEMENT 


Fig.  5.6:  Character  Search  Flowchart 

A  Block  Transfer  Routine  for  Fewer  Than  256  Elements 

We  will  call  "COUNT"  the  number  of  elements  in  the  block  to  be 
moved.  The  number  is  assumed  to  be  less  than  256.  FROM  is  the  base 
address  of  the  block.  TO  is  the  base  of  the  memory  area  where  it  should 
be  moved.  The  algorithm  is  quite  simple;  we  will  move  a  word  at  a  time, 
keepmg  track  of  which  word  we  are  moving  by  storing  its  position  m 
the  counter  C,  The  program  appears  below: 


GET  WORD 


BLKMOV 

LD 

IX,  FROM 

LD 

lY,  TO 

LD 

BC,  COUNT 

NEXT 

LD 

A,  (IX) 

LD 

(lY),  A 

INC 

iX 

INC 

lY 

DEC 

C 

JR 

NZ,  NEXT 

Let  us  examine  it: 

BLKMOV 

LD 

IX,FROM 

LD 

lY.TO 

LD 

C,  COUNT 

These  three  mstructionsinitiaiize  registers  IX,  lY,  and  C  respectively,  as 
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A[: 


MEMORY 


COUNT 


SOURCE 


DESTINATION 


1 

1  j 

1  ! 

1 —  

^1  1 

;  FROM 


TO 


Fig.  5.7:  Block  Transfer:  Initializing  the  Register 

illustrated  in  Figure  5.7,  Index  register  IX  is  used  as  the  source  pointer, 
and  will  be  incremented  regularly.  Index  register  lY  is  used  as  tlie  desti- 
nation pointer,  and  would  be  incremented  regularly.  Register  C  is  load- 
ed with  the  maximum  number  of  elements  to  be  transferred  (limited  to 
256  since  this  is  an  eight-bit  register)  and  will  be  decremented  regularly. 
Whenever  C  decrements  to  zero,  all  elements  have  been  transferred. 
The  next  two  instructions: 


NEXT 


LD 
LD 


A,  (IX) 
(lY),  A 


load  the  contents  of  the  memory  location  pointed  to  by  IX  into  the  ac- 
cumulator, then  transfer  it  into  the  memory  location  pointed  to  by  reg- 
ister lY.  In  other  words,  these  two  instructions  transfer  an  element  of 
the  source  block  into  the  destination  block.  The  two  index  registers  are 
then  incremented: 

INC  IX 
INC  !Y 

And  the  counter  register  is  decremented: 
DEC  C 

Finally,  as  long  as  the  counter  is  not  0,  the  program  loops  back  to  the 
label  NEXT: 


JR      NZ,  NEXT 
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This  !s  an  example  of  the  possible  utilization  of  index  registers.  How- 
ever, let  us  compare  it  to  the  same  program  written  for  another  micro- 
processor, the  MOS  Technology  6502,  which  is  also  equipped  with  an 
indexing  capability,  but  uses  different  conventions  (i.e.,  has  different 
limitations  on  a  general-purpose  indexing  faciHty).The  program  appears 
below: 


Without  gomg  into  the  details  of  the  above  program,  the  reader  wit! 
immediately  notice  how  much  shorter  it  is  than  the  previous  one.  This  is 
because  the  inde.x  register  X  is  used  as  a  variable  displacement,  whereas 
FROM  and  TO  are  used  as  the  fixed  source  and  destination  addresses. 

This  example  should  point  out  that  although  in  theory  indexing  is  a 
powerful  facility,  ii  does  not  necessarily  lead  to  efficient  coding,  due  to 
the  addressing  limitations  imposed  on  it  in  the  case  of  various  micro- 
processors. Truly  general-purpose  indexing  requires  the  possibility  of  a 
16-bit  displacement  or  address  field  as  well  as  a  16-bit  index  register. 

However,  it  should  be  noted  that  this  specific  problem  is  solved,  in 
the  Z80  by  the  presence  of  specialized  instructions.  A  general-purpose 
block  transfer  will  now  be  described  which  can  be  implemented  m  just 
four  instructions.  However,  to  be  fair  to  the  Z80,  let  us  suggest  addi- 
tional exercises  for  the  reader: 

Exercise  5.1:  Write  ihe  block  transfer  program  for  the  Z80  in  the  style 
of  the  above  program  for  the  6502,  i.e. ,  assuming  that  the  inde.x  register 
contains  a  displacement.  Assume  that  the  source  and  the  destination 
block  are  located  m  page  0,  i.e.,  at  addresses  0  to  256.  Naturally,  it  will 
be  assumed  thai  the  number  of  elements  within  each  block  is  small 
enough  that  they  do  not  overlap. 

E.sercise  5.2:  Assume  now  that  the  source  and  the  destination  blocks  are 
located  anywhere  m  the  memory,  except  that  they  are  both  within  the 
same  page.  Rewrite  the  above  program  in  that  case.  (Is  there  a  dif- 
ference. I.e.,  does  page  zero  play  any  role  for  the  Z80?) 

Generalized  Block  Transfer  Routine  (More  Than  256  Elements) 

The  register  allocation  and  the  memory  map  are  shown  m  Figure  5.8. 


NEXT 


LDX 

LDA 

STA 

DEX 

BNE 


^NUMBER 
FROM,  X 
TO,  X 


NEXT 
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The  program  is  shown  below: 


LD  BC,  COUNT 
LD  DE,  TO 
LD  HL,  FROM 
LDIR 


NUMBER  OF  BYTES 
DESTINATION  ADDRESS 
START  ADDRESS 
TRANSFER  ALL  BYTES 


Memory  used:  11  bytes 

Timing:  21  cycles/byte  transferred 

The  first  instruction  is: 


BC,  COUNT 


It  loads  the  number  of  elements  to  be  transferred  (a  16-bit  value)  into 
the  register  pair  BC.  The  next  two  instructions  initialize  the  register  pair 
DE  and  the  register  pair  HL  respectively: 


LD 
LD 


DE,  TO 
HL,  FROM 


Finally  the  fourth  instruction; 
LDIR 

performs  the  complete  transfer. 

LDIR  is  an  automated  biock- transfer  instruction.  Its  power  should 
be  obvious  from  this  example.  LDIR  results  in  the  following  sequence: 
The  contents  of  the  memory  location  pointed  to  by  H  and  L  are  trans- 
ferred into  the  memory  location  pointed  to  by  DE:  (DE)  =(HL).  Next, 
DE  is  incremented:  DE  =  DE  +  1.  Then,  HL  is  incremented:  HL  = 
HL  +  i.  Next,  BC  is  decremented:  BC  =  BC  -  1.  If  BC  becomes  0,  the 
instruction  is  terminated.  Otherwise,  the  instruction  is  repeated. 


COUNTER 


DESTINATION 


SOURCE 


REGISTERS 


MEMORY 

Fig.  5.8:  A  Block  Transfer-Memory  Map 
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The  value  and  power  of  the  LDIR  instruction  should  be  apparent  at 
this  point  without  further  comments.  Similarly,  our  search  for  the  char- 
acter "star"can  be  improved  by  the  use  of  an  automated  instruction, 
CPIR,  special  to  the  Z80.  The  corresponding  program  appears  below: 

LD  A, 

LD  BC,  COUNT 
LD  HL,  STRING 
STAR  CPIR 

JR  Z,  STAR 

NOSTAR 

The  first  instruction  loads  the  accumulator  with  the  code  for  the 
character  star.  Next,  the  register  pair  BC  is  initialized  to  the  count  of 
the  number  of  words  to  be  searched  within  the  block: 

LD  BC.  COUNT 

The  register  pair  H  and  L  is  set  to  the  starting  address  of  the  block  to 
be  searched  (STRING).  The  automated  instruction  is  then  executed; 

LD  HL..  STRING 
CPIR 

The  CPIR  instruction  is  an  automated  compare  mstruciion.  The  con- 
tents of  the  memory  location  specified  by  the  address  contained  in  H 
and  L  is  compared  to  the  contents  of  the  accumulator.  If  the  compari- 
son succeeds,  then  Z  of  the  flags  register  will  be  set  to  i.  Then,  the  reg- 
ister pair  H  and  L  is  incremented  and  the  register  pair  BC  is 
decremented.  The  instruction  is  repeated  until  either  the  pair  BC  goes  to 
0  or  else  the  comparison  succeeds.  After  the  instruction  CPIR  is  ex- 
ecuted, it  is  therefore  necessary  to  test  the  Z  flag  to  determine  whether 
the  comparison  has  succeeded  (the  CPIR  might  have  looped  through 
64K  words  without  success  in  the  extreme  case).  This  is  the  purpose  of 
the  last  instruction  of  the  program: 

JR  Z,  STAR 

Exercise  5.3:  Rewrite  (he  above  program  so  that  a  search  proceeds 
backwards.  (Hint:  Use  the  CPDR  instruction)  Continue  the  block 
transfer  until  "''is  found. 

Let  us  now  develop  a  program  combining  the  features  of  the  two  pre- 
vious ones.  We  wilt  implement  the  block  transfer  from  location  FROM 
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to  locaEion  TO,  which  shall  stop  aulomatically  whenever  an  escape 
character,  "star",  is  found.  The  program  appears  below: 

LD      BC,  COUNT 
LD     HL,  FROM 
LD      DE,  TO 

LD    A,'*'  DELIMITER  (ESCAPE  CHAR) 

TEST     CP  (HL)  COMPARE  WITH  MEMORY 

CHARACTER 
JR      Z,  END  END  IF  SUCCESS 

LDl  TRANSFER  CHARACTER  AND 

UPDATE  POINTERS  AND 

COUNT 

JP      PE,  TEST  KEEP  TESTING  UNLESS  DONE 

P/V  INDICATES  WHETHER  BC  =  0 

The  first  three  instructions  of  the  program  perform  the  usual  mitiaii- 
zatson,  setting  up  the  counter  registers  and  the  source  and  destination 
pointers: 

LD    BC,  COUNT 
LD    HL,  FROM 
LD    DE,  TO 

The  star  character  is  deposited,  "as  usual"  into  the  accumulator,  so 
that  it  can  be  compared  to  the  character  read  from  a  memory  location. 

LD  A,'*' 

This  IS  exactly  what  is  done  by  the  next  instruction: 

TEST     CP  (HL) 

The  success  or  failure  of  the  comparison  is  determined  by  testing  the  Z 
bit.  The  Z  bit  will  have  been  set  if  the  comparison  has  succeeded.  This  is 
performed  by  the  next  instruction; 

JR  Z,  END 

The  next  instruction  is  an  automated  transfer  instruction: 
LDI 

This  instruction  transfers  the  character,  and  updates  the  pointers  and 
the  count  m  a  single  instruction.  LDI  transfers  the  contents  pointed  to 
by  H  and  L  into  the  memory  location  pointed  to  by  D  and  E:  (DE)  = 
(HL).  it  increments  DE  and  HL; 

DE  =  DE  +  1 
HL  =  HL  +  1 
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Finally,  it  decrements  BC;  EC  becomes  BC  -1.  The  particularity  of 
this  instruction  is  that  the  P/V  flag  is  cleared  if  BC  decrements  to  "0" 
and  set  otherwise.  This  will  be  explicitly  tested  by  the  last  instruction  in 
the  program  to  determine  whether  exit  should  occur: 

JP    PE,  TEST 

Adding  Two  Blocks 

A  program  will  be  developed  here  to  add  element!  by  •  element  two 
blocks  starting  respectively  at  addresses  BLKl,  and  BLK2,  and  having 


BLKADD 


LOOP 


LD 

IX,  BLKl 

lY,  BLK2 

LD 

B,  COUNT 

XOR 

A 

LD 

A,  (IX  +  0) 

ADC 

A,  (lY  +  0) 

LD 

{IX),  A 

DEC 

!X 

DEC 

lY 

DEC 

B 

JR 

NZ,  LOOP 

B  COUNTER 


MEMORY 

Fig.  5.9:  Adding  Two  Blocks:  BLKl  =  BLKl  +  BLK2 
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The  memory  layout  is  shown  in  Figure  5.9,  The  program  is  straightfor- 
ward. The  number  of  elements  to  be  added  is  loaded  into  the  counter 
register  B,  and  the  two  mdex  registers  IX  and  lY  are  initialized  to  their 
values  BLKl  and  BLK2: 

BLK  ADD  LD  IX,  BLKl 
LD  lY.  BLK2 
LD    B,  COUNT 

The  carry  bit  is  then  cleared  in  anticipation  of  the  first  addition; 
XOR  A 

The  first  element  is  loaded  into  the  accumulator; 

LOOP  LD    A,  {IX  +  0) 

The  corresponding  element  of  BLK2  is  then  added  to  it: 

ADC    A,  (lY  +0) 
and  finally  saved  mto  the  element  of  BLKl: 

LD    (IX),  A 

The  two  pointer  registers  X  and  Y  are  decremented; 

DEC  IX 
DEC  lY 

as  well  as  the  counter  register: 

DEC  B 

As  long  as  the  counter  register  is  not  0,  the  addition  loop  is  executed: 
JR   NZ,  LOOP 

Exercise  5.4:  Can  you  use  the  above  program  to  perform  a  32-bit  addi- 
Uon? 

Exercise  5.5:  Can  you  use  the  above  program  lo  perform  a  64-bit  addi- 
(lon? 

Exercise  5.6:  Modify  the  above  program  so  that  the  result  rs  stored  in  a 
separate  block  startmg  at  address  BLK3. 

Exercise  5. 7:  Modify  the  above  program  to  perform  a  subtraction 
rather  than  an  addition. 
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Exercise  5.8:  Modify  the  original  program  above  so  (hat  BLKl  and 
BLK2  are  at  the  top  of  each  block  rather  than  the  bottom  (see  Fig.5. 10). 


fROM  - 

COUNT  =  N 


SOURCE  BtOCK 


TO- 


OESTtNAlsON  BLOCK 


Fig-  5.10:  Memory  Organization  for  Block  Transfer 


SUMMARY 

A  complete  description  of  addressing  modes  has  been  presented.  It. 
has  been  shown  that  the  Z80  offers  many  possible  mechanisms,  and  the 
specific  addressing  modes  available  on  the  Z80  have  been  analyzed. 
Finally,  several  application  programs  have  been  presented  to  demon- 
strate the  value  of  the  various  addressing  mechanisms.  Programming 
the  Z80  efficiently  requires  an  understanding  of  these  mechanisms. 
They  will  be  used  throughout  the  programs  in  the  remainder  of  this 
book, 

EXERCISES 

5.9:  Write  a  program  to  add  the  first  10  bytes  of  a  table  stored  at  loca- 
tiort  "BASE".  The  result  will  have  16  bits.  (This  is  a  checksum  com- 
putation). 

5. 10:  Can  you  solve  the  same  problem  without  using  the  indexing 
mode? 
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5,//;  Reverse  the  order  of  she  10  bytes  of  this  table.  Store  the  result 
at  address  "REVER". 

5.12:  Search  the  same  table  for  its  largest  element.  Store  it  at  memory 
address  "LARGE", 

5.!S:  Add  together  the  corresponding  elements  of  three  tables,  whose 
bases  are  BASEL  BASE!,  BASES.  The  length  of  these  tables  is  stored 
a!  address  '•LENGTH"- 
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INTRODUCTION 

We  have  learned  so  far  how  to  exchange  information  between  the 
memory  and  the  various  registers  of  the  processor.  We  have  learned  to 
manage  the  registers  and  to  use  a  variety  of  instructions  to  manipulate 
the  data.  We  must  now  learn  to  communicate  with  the  external  world. 
This  !s  called  input/output. 

Input  refers  to  the  capture  of  data  from  outside  peripherals  (key- 
board, disk,  or  physical  sensor).  Output  refers  to  the  transfer  of  data 
from  the  microprocessor  or  the  memory  to  external  devices  such  as  a 
printer,  a  CRT,  a  disk,  or  actual  sensors  and  relays. 

We  will  proceed  in  two  steps.  First,  we  will  learn  to  perform  the  input  / 
output  operations  required  by  common  devices.  Secondly,  we  will 
learn  to  manage  several  input/output  devices  simultaneously,  i.e.,  to 
schedule  them.  This  second  part  will  cover,  in  particular,  polling  vs.  in- 
terrupts. 

INPUT/OUTPUT 

In  this  section  we  will  learn  to  sense  or  to  generate  simple  signals, 
such  as  pulses.  Then  we  will  study  techniques  for  enforcing  or  measur- 
ing correct  timmg.  We  will  then  be  ready  for  more  complex  types  of  in- 
put/output, such  as  high-speed  serial  and  parallel  transfers. 

The  Z80  Input/Output  Instructions 

The  Z80  is  equipped  with  a  special  set  of  input  and  output  instruc- 
tions. Most  eight-bit  microprocessors  are  not  equipped  with  a  special 
set  of  input  and  output  instructions,  and  use  the  general  mstruction  set 
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on  input/output  devices.  The  Z80,  iike  the  8080,  is  equipped  with  basic 
input  and  output  instructions.  However,  the  280  is  also  equipped  with 
additional  I/O  instructions.  These  will  be  described  in  more  detail  here 
m  order  to  facilitate  understanding  of  the  programs  that  will  be  pre- 
sented throughout  this  section. 

The  basic  input  and  output  instructions  are  respectively:  IN  A,  (n) 
and  OUT  {n),A-  These  two  instructions  are  inherited  from  the  8080. 
They  will  respectively  read  or  write  one  byte  between  the  selected  port 
and  the  accumulator.  The  actual  addressing  process  is  such  that  the  1,0 
device  address  "n"  is  gated  on  lines  AO  through  A7  of  the  address  bus, 
while  the  contents  of  the  accumulator  appear  on  address  lines  A8  through 
A15.  When  only  256  devices  are  addressed,  it  may  be  necessary  to  zero 
the  contents  of  the  accumulator  explicitly  if  any  of  the  address  lines  AS 
through  Ai5  may  be  decoded  by  an  I/O  device.  In  the  simple  examples 
that  follow,  we  will  assume  that  fewer  than  256  devices  are  present  and 
that  they  are  not  connected  to  addresses  A8  through  A15,  so  that  it  will 
not  be  necessary  to  zero  the  contents  of  the  accumulator  explicitly,  for 
example  prior  to  usmg  the  IN  instruction. 

A  special  input  instruction:  IN  r,  (C),  allows  using  the  contents  of 
register  C  as  the  1/0  device '.address.  When  using  thss  instruction,  the 
contents  of  register  B  automatically  provide  the  top  part  of  the  address 
(A8  through  A15).  The  specified  register  r  is  loaded  from  the  specified 
address,  "r"  may  be  any  of  the  usual  seven  general-purpose  registers. 

Generate  a  Signal 

In  the  simplest  case,  an  output  device  will  be  turned  off  (or  on)  from 
the  computer.  In  order  to  change  the  state  of  the  output  device,  the  pro- 
grammer will  merely  change  a  level  from  a  logical  "0"  to  a  logical  "I", 
or  from  "I"  to  "0".  Let  us  assume  that  an  external  relay  is  connected 
to  bit  "0"  of  a  register  called  "OUTI".  In  order  to  turn  it  on,  we  will 
simply  write  a  "1"  into  the  appropriate  bit  position  of  the  register.  We 
assume  here  that  OUTI  represents  the  address  of  this  output  register 
within  our  system.  A  program  which  will  turn  the  relay  on  is: 

TURNON    LD  A,  00000001 B  LOAD  PATTERN  INTO  A 

OUT  (OUTI),  A  OUTPUT  IT  TO  DEVICE 

where  OUT  is  the  output  mstruction. 

We  have  assumed  that  the  state  of  the  other  seven  bits  of  the  register 
OUTI  is  irrelevant.  However,  this  is  often  not  the  case.  These  bits 
might  be  connected  to  other  relays.  Let  us,  therefore,  improve  this  sim- 
ple program.  We  want  to  turn  the  relay  on,  without  changing  the  state 


461 


PROGRAMMING  THE  Z80 


of  any  other  bit  within  this  register.  We  will  assume  that  it  is  possible  to 
read  and  write  the  contents  of  this  register.  Our  improved  program  now 
becomes: 


TURNON 


IN  A,  (OUTl) 
OR  0000000  IB 
OUT  (OUTl),  A 


READ  CONTENTS  OF  OUTl 
FORCE  BIT  "0"  TO  "1"  IN  A 


The  program  first  reads  the  contents  of  location  OUTl,  then  per- 
forms an  inclusive  OR  on  its  contents.  This  oniy  changes  bit  position  0 
to  "1",  and  leaves  the  rest  of  the  register  intact.  (For  more  details  on 
the  OR  operation,  refer  to  Chapter  4.)  This  is  illustrated  by  Figure  6. 1. 


o 

OUI  I 


StlAY 

1 

Fig.  6.1:  Turning  on  a  Relay 

Pulses 

Generating  a  pulse  is  accomplished  exactly  as  m  the  case  of  the  level 
above.  An  output  bit  is  first  turned  on,  then  later  turned  off.  This  re- 
sults in  a  pulse.  This  is  illustrated  in  Figure  6.2,  This  time,  however,  an 
additional  problem  must  be  solved:  one  must  generate  the  pulse  for  the 
correct  length  of  time.  Let  us,  therefore,  study  the  generation  of  a  com- 
puted delay. 


0 

0 

0 

a 

0 

D 

t 

fflEPBOOaAM'  SJlECr  OUTPUT  POST 
iOAD  OUTPUT  PO*iI  HEG'STEB  WITHFAriEttN 
WAIT  llOOFFOSNUSECi 
lOAO  OUTPUT  KJSI  WI!H  ZEBO 
StTUHN 


Fig.  6.2:  A  Programmed  Pulse 
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Delay  Generation  and  Measurement 

A  delay  may  be  generated  by  software  or  by  hardware  methods.  We 
will  here  study  the  way  to  perform  it  by  program,  and  later  show  how  it 
can  also  be  accomplished  with  a  hardware  counter,  called  a  program- 
mable interval  timer  (PIT). 

Programmed  delays  are  achieved  by  counting.  A  counter  register  is 
loaded  with  a  value,  then  is  decremented.  The  program  loops  on  itself 
and  keeps  decrementing  until  the  counter  reaches  the  value  "O'V  The 
total  length  of  time  used  by  this  process  will  implement  the  required 
delay.  As  an  example,  let  us  generate  a  delay  of  82  clock  cycles; 


This  program  loads  A  with  the  value  5.  The  next  instruction  decre- 
ments A  and  the  following  instruction  will  cause  a  branch  to  NEXT  to 
occur  as  long  as  A  does  not  decrement  to  "0"  When  A  finally  decre- 
ments to  zero,  the  program  will  exit  from  this  loop  and  execute  what- 
ever instruction  follows.  The  logic  of  the  program  is  simple  and  appears 
in  the  flowchart  of  Figure  6.3, 

Let  us  now  compute  the  effective  delay  which  will  be  implemented  by 
the  program.  In  Chapter  4  of  the  book,  we  will  look  up  the  number  of 
cycles  required  by  each  of  these  instructions: 

LD  in  the  immediate  mode  requires  seven  clock  cycles.  DEC  will  use 
four  cycles.  Finally,  JR  will  use  12  cycles  except  during  the  last  itera- 
tion, where  it  will  use  7  cycles.  When  looking  up  the  number  of  cycles 
for  JR  in  the  table,  verify  that  two  possibilities  exist;  if  the  branch  does 
not  occur,  JR  will  only  require  seven  cycles.  If  the  branch  does  succeed, 
which  will  usually  be  the  case  during  the  loop,  then  12  cycles  are  re- 
quired. 

The  timing  is,  therefore,  seven  cycles  for  the  first  instruction,  plus  1 1 
cycles  for  the  next  two,  multiplied  by  the  number  of  times  the  loop  will 
be  executed,  minus  an  extra  five-cycle  delay  for  the  last  unsuccessful  JR: 

Delay  =  7+  16x5-5  =  82  cycles. 

Assuming  a  .5  microsecond  cycle,  this  programming  delay  will  be  41 
microseconds. 


DELAY 
NEXT 


LD 

DEC 

JR 


A,  5 
A 

NZ,NEXT 


A  IS  COUNTER 
DECREMENT 
NEXT  TEST 
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COUNTER  =  VALUE 


DECREMENT  COUNTER 


OUT 

Fig.  6.3:  Basic  Delay  Flowciiart 


The  delay  loop  which  has  been  described  is  used  by  most  mpui/output 
programs,  il  should  be  well  undersiood.  Try  to  do  the  following  exercises: 

Exercise  6. 1:  What  are  the  inaxinium  and  the  minitmiin  delays  which 
can  be  implenienred  with  these  three  instruciions? 

Exercise  6.2:  Modify  the  program  to  obtain  a  delay  of  about  100  micro- 
seconds. 

If  one  wishes  to  implement  a  longer  delay,  a  simple  solution  is  to  add 
extra  instructions  in  the  program,  before  DEC.  The  simplest  way  to  do 
so  is  to  add  NOP  instruction.  (The  NOP  does  nothing  for  four  cycles.) 

Longer  Delays 

Generating  longer  delays  by  software  can  be  achieved  through  using 
a  wider  counter,  A  register  pair  can  be  used  to  hold  a  16-bit  count.  To 


464 


INPUT/OUTPUT  TECHNIQUES 


simplify,  let  us  assume  that  the  lower  count  is  "0",  The  lower  byte 
will  be  loaded  with  "0",  the  maximum  count,  then  go  through  a 
decrementation  loop.  Since  the  first  decrementation  results  in  00-*-FF 
and  does  not  affect  the  2  flag  whenever  it  is  decremented  to  "0",  the 
upper  byte  of  the  counter  wiil  be  decremented  by  J .  Whenever  the  up- 
per byte  is  decremented  to  the  value  "0",  the  program  terminates.  If 
more  precision  is  required  in  the  delay  generation,  the  lower  count  can 
have  a  non-null  value.  In  this  case,  we  would  write  the  program  just  as 
explained  and  add  at  the  end  the  three-line  delay  generation  program, 
which  has  been  described  above. 

A  24-bit  delay  program  appears  below; 


DEL24 
DEL  16 
LOOPA 
LOOPB 


B,  COUNTH 
DE,  -1 

HL,  COUNTL 
HL.  DE 

C.  LOOPB 
LOOPA 


COUNTER  HIGH  (8  BITS) 


COUNTER  LOW 
DECREMENT  IT 
GO  ON  UNTIL  NULL 
DECREMENT  B  AND  JUMP 
and  used  to  decrement  the  16-bit 


LD 
LD 
LD 
ADD 
JR 

DJN2 

Note  that  DE  is  loaded  with  "  -  I 
counter  HL. 

Naturally,  still  longer  delays  could  be  generated  by  usmg  more  than 
three  words.  This  is  analogous  to  the  way  an  odometer  works  on  a  car. 
When  the  nght-most  wheel  goes  from  "9"  to  "0",  the  next  wheel  to  the 
left  is  mcremented  by  1.  This  is  the  general  principle  when  counting 
with  multiple  discrete  units. 

However,  the  main  disadvantage  of  this  method  is  thai  when  one  is 
counting  delays,  the  microprocessor  will  be  doing  nothing  else  for  hun- 
dreds of  milliseconds  or  even  seconds.  If  the  computer  has  nothing  else 
to  do,  this  IS  perfectly  acceptable.  However,  in  general  the  microcom- 
puter should  be  available  for  other  tasks,  so  that  longer  delays  are  nor- 
mally not  implemented  by  software.  In  fact,  even  short  delays  may  be 
objectionable  m  a  system  if  it  is  to  provide  some  guaranteed  response 
time  in  given  situations.  Hardware  delays  must  then  be  used.  In  addi- 
tion, if  interrupts  are  used,  timing  accuracy  may  be  lost  if  the  counting 
loop  can  be  interrupted. 

Exercise  6,3:  Wnle  a  program  to  iinplenient  a  100  ms  delay  (typical  of  a 
Teletype). 

Hardware  Delavs 


Hardware  delays  are  implemented  by  using  a  programmable  interval 
timer  or  "timer"  in  short.  A  register  of  the  timer  is  loaded  with  a  value. 
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The  difference  is  that  the  timer  will  automatically  decrement  the 
counter  periodically.  The  period  can  usually  be  adjusted  or  selected  by 
the  programmer.  Whenever  the  timer  has  decremented  to  "0",  it  will 
normally  send  an  mterrupi  to  the  microprocessor.  It  may  also  set  a 
status  bit  which  can  be  sensed  periodically  by  the  computer.  The  use  of 
mterrupts  will  be  e.xplamed  later  m  this  chapter. 

Other  timer  operating  modes  may  include  starling  from  "0"  and 
counting  the  duration  of  the  signal,  or,  counting  the  number  of  pulses 
received.  When  functiomng  as  an  mterval  timer,  the  timer  is  said  to 
operate  in  a  one-shot  mode.  When  counting  pulses,  it  is  said  to  operate 
in  a  pulse  counting  mode.  Some  timer  devices  may  even  include  mul- 
tiple registers  and  a  number  of  optional  facilities  which  the  programmer 
can  select. 

Sensing  Pulses 

The  problem  with  sensing  pulses  ss  the  reverse  of  that  of  generating 
pulses,  and  includes  one  more  difficulty:  whereas  an  output  pulse  is 
generated  under  program  control,  input  pulses  occur  asynchronously 
with  the  program.  In  order  to  detect  a  pulse,  two  methods  may  be  used: 
polling  and  interrupts.  Interrupts  will  be  dLscus.sed  later  in  this  chapter. 

Let  us  now  consider  the  polling  technique.  Using  this  technique,  the 
program  reads  the  value  of  a  given  input  register  continuously,  testing  a 
bit  position,  perhaps  bit  0.  U  will  be  assumed  that  bit  0  is  originally 
"0".  Whenever  a  pulse  is  received,  this  bit  will  lake  the  value  "1"-.  The 
program  continuously  monitors  bit  0  until  it  takes  the  value  "  1 "-  When 
a  "I"  is  found,  the  pulse  has  been  detected.  The  program  appears 
below: 

POLL       IN        A,  (INPUT)  READ  INPUT  REGISTER 

ON  BIT      0,  A  TEST  FOR  0 

JR        Z,  POLL  KEEP  POLLING  IF 0 

Conversely,  let  us  assume  that  the  input  line  is  normally  "! "  and  that 
we  wish  to  detect  a  "0" ,  This  is  the  usual  case  for  delecting  a  START 
bit,  when  monitoring  a  line  connected  to  a  Teletype,  The  program  ap- 
pears below: 

POLL       IN        A,  (INPUT)  READ  INPUT  REGISTER 

BIT      0,  A  SET  Z  FLAG 

JR        NZ,  POLL  TEST  IS  REVERSED 

START  ... 


466 


INPUT/OUTPUT  TECHNIQUES 


Monitoring  the  Duration 

Monitoring  the  duration  of  the  pulse  may  be  accomplished  in  the 
same  way  as  computing  the  duration  of  an  output  pulse.  Either  a  hard- 
ware or  a  software  technique  may  be  used.  When  monitonng  a  puise  by 
software,  a  counter  is  regularly  incremented  by  i,  then  the  presence  of 
the  pulse  is  verified.  If  the  pulse  is  stiil  present,  the  program  loops  upon 
itself.  Whenever  the  pulse  disappears,  the  count  contained  in  the 
counter  register  is  used  to  compute  the  effective  duration  of  the  pulse. 
The  program  appears  below: 


DURTN 

LD 

B,  0 

CLEAR  COUNTER 

AGAIN 

IN 

A,  (INPUT) 

READ  INPUT 

BIT 

0,  A 

MONITOR  BIT  0 

JR 

Z,  AGAIN 

WAIT  FOR  A  "1" 

LONGER 

INC 

B 

INCREMENT  COUNTER 

IN 

A,  (INPUT) 

CHECK  BIT  0 

BIT 

0,  A 

JR 

NZ,  LONGER 

WAIT  FOR  A  "0" 

Naturally,  we  assume  that  the  maximum  duration  of  the  pulse  will 
not  cause  register  B  to  overflow.  If  this  were  the  case,  the  program 
would  have  to  be  changed  to  take  that  into  account  (or  else  it  would  be  a 
programming  error!). 

Since  we  now  know  how  to  sense  and  generate  pulses,  let  us  capture 
or  transfer  larger  amounts  of  data.  Two  cases  will  be  distinguished: 
serial  data  and  parallel  data.  Then  we  will  apply  this  knowledge  to  ac- 
tual input/output  devices. 

PARALLEL  WORD  TRANSFER 

It  IS  assumed  here  that  eight  bits  of  transfer  data  are  available  in  par- 
allel at  address  "INPUT"  (see  Fig.  6.4).  The  microprocessor  must  read 
the  data  word  at  this  location  whenever  a  status  word  indicates  that  it  is 
valid.  The  status  information  will  be  assumed  to  be  contained  m  bit  7  of 
address  "STATUS",  We  will  here  write  a  program  which  will  read  and 
automatically  save  each  word  of  data  as  it  comes  in.  To  simplify,  we 
will  assume  that  the  number  of  words  to  be  read  is  known  in  advance 
and  IS  contained  in  location  "COUNT".  If  this  information  were  not 
available,  we  would  test  for  a  so-called  break  character,  such  as  a 
rubout,  or  perhaps  the  character  "*",  We  have  learned  to  do  this  al- 
ready. 
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COUNT 


STATUS 


INPUT 


VAUD 


V 


8  BITS 


I/O  DEVICE 


7  0 

Fig.  6.4:  Parallel  Word  Transfer- The  Memory 


The  flowchart  appears  m  Figure  6.5.  it  is  quite  straightforward.  We 
lest  the  status  information  until  u  becomes  "  1 indicating  that  a  word 
15  ready.  When  the  word  is  ready,  we  read  it  and  save  it  at,  an  appropri- 
ate memory  location.  We  then  decrement  the  counter  and  test  whether 
It  has  decremented  to  "0",  If  so,  we  are  finished;  if  not,  we  read  the 
next  word.  A  simple  program  which  implements  this  algorithm  appears 
below: 

PARAL    LD       A,  (COUNT)   READ  COUNT  INTO  A 

LD       B,  A  B  IS  COUNTER 

WATCH  IN        A,  (STATUS)  LOOK  FOR  'DATA  READY' 

TRUE 

BIT      7,  A  BIT  7  IS  "1"  IF  DATA  READY 

JR        Z,  WATCH     DATA  VALID? 
IN        A,  (INPUT)     READ  DATA 


PUSH  AF 


SAVE  DATA  INTO  STACK 
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DEC     B  DECREMENT  COUNT 

JR       NZ,  WATCH  DO  IT  UNTIL  ZERO 

It  IS  assumed  that  the  "data  ready"  flag  is  automalicaiiy  cleared  when 
STATUS  IS  read. 
The  first  two  instructions  initiaiize  the  counter  register  B: 

PARAL       LD  A,  (COUNT) 
LD       B.  A 

Note  that  there  is  no  easy  way  to  load  B  only  from  memory.  One  must 
either  load  A,  then  transfer  its  contents  to  B,  or  load  B  and  C 
simultaneously. 


Fig.  6.5:  Parallel  Word  Transfer:  Flowchart 
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The  next  three  instructions  of  the  program  read  the  status  mforma- 
tion  and  cause  a  loop  to  occur  as  long  as  bit  seven  of  the  status  register 
IS  "0".  (It  is  the  sign  bit,  i.e.,  bit  N.) 

IN  A,  (STATUS) 

BIT  7,  A  "IN"  DOES  NOT  SET  THE  FLAGS 

JR  Z,  WATCH 

When  JP  fails,  data  is  valid  and  we  can  read  it: 

IN  A.  (INPUT) 

The  word  has  now  been  read  from  address  INPUT  where  it  was,  and 
must  be  saved,  Assummg  that  a  sufficient  stack  area  is  available,  we 
can  use: 

PUSH  AF 

which  saves  A  (and  F)  in  the  stack.  If  the  stack  is  full,  or  the  number  of 
words  to  be  transferred  is  large,  we  could  not  push  them  on  the  stack 
and  we  would  have  to  transfer  them  to  a  designated  memory  area,  us- 
ing, for  example,  an  indexed  instruction.  However,  this  would  require 
an  extra  instruction  to  increment  or  decrement  the  index  register. 
PUSH  is  faster  (only  1 1  clock  cycles). 

The  word  of  data  has  now  been  read  and  saved.  We  will  simply  decre- 
ment the  word  counter  and  test  whether  we  are  finished: 

DEC  B 

JR  NZ.WATCH 

This  nine-instruction  program  can  be  called  a  benchmark.  A  benchmark 
program  is  a  carefully  optimized  program  designed  to  test  the  capabilities 
of  a  given  processor  in  a  specific  situation.  Parallel  transfers  are  one  such 
typical  situation.  This  program  has  been  designed  for  maximum  speed  and 
efficiency.  Let  us  now  compute  the  maximum  transfer  speed  of  this  pro- 
gram. We  will  assume  that  COUNT  is  contained  in  memory.  The  duration 
of  every  instruction  is  determined  by  inspecting  the  tables  in  Chapter  Four 
and  is  found  to  be  the  following: 


PARAL 

LD 

A,  (COUNT) 

13 

LD 

B,  A 

4 

WATCH 

IN 

A,  (STATUS) 

11 

BIT 

7,  A 

8 

JR 

Z,  WATCH 

7/12 
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IN         A,  (INPUT)  !i 
PUSH   AF  !i 
DEC     B  4 
JR        NZ,  WATCH  7/12 

The  minimum  execution  (ime  is  obtained  by  assuming  that  data  is 
available  every  time  that  we  sample  STATUS.  In  other  words,  the  first 
JP  will  be  assumed  to  fail  every  time.  Timing  is  then: 

13  +  4  +  (11  +  8  +  7  +  11  +  4  +  12)  *  COUNT 

Neglecting  the  first  17  cycles  necessary  lo  initialize  the  counter  regis- 
ter, the  time  used  to  transfer  one  word  is  64  clock  cycles  or  32 
microseconds  with  a  2  MHz  clock. 

The  maximum  data  transfer  raie  is,  therefore; 
( 

  =  3 1  K  bytes  per  second 

32  (10-') 

Exercise  6.4:  Assume  ihai  (he  inimher  of  words  to  be  sninsferred  is 
greaier  than  256.  Modify  the  program  accordingly  and  deiermtne  the 
impacl  un  the  maxitinini  data  transfer  rale. 

E.xercise  6. 5:  Modify  tins  program  m  order  to  try  m  improve  its  speed: 

1 —  using  JR  instead  of  JP 

2—  usmg  DJNZ 

3—  using  INI  or  IND 

Was  the  above  program  truly  optimal? 

We  have  now  learned  to  perform  high-speed  parallel  transfers.  Let  us 
consider  a  more  complex  case. 

BIT  SERIAL  TRANSFER 

A  serial  input  is  one  m  which  the  bits  of  information  (O's  or  1  'si  come 
in  successively  on  a  line.  The.se  bits  may  come  in  at  regular  intervals. 
This  IS  normally  called  synchronous  transmission.  Or,  they  may  come 
as  bursts  of  data  ai  random  intervals.  This  is  called  asynchronous  iran.s- 
mission.  We  will  develop  a  program  which  can  work  m  both  cases.  The 
principle  of  the  capture  of  sequential  data  is  simple:  we  will  watch  an 
input  line,  which  wili  be  assumed  to  be  line  0.  When  a  bit  of  data  is  de- 
tected on  this  line,  we  will  read  the  bit  in,  and  shift  u  into  a  holding  reg- 
ister. Whenever  eight  bits  have  been  assembled,  we  will  preserve  the 
byte  of  data  into  the  memory  and  as.sembie  the  next  one.  In  order  to 
simplify,  we  will  a.ssume  that  the  number  of  bytes  to  be  received  is 


471 


PROGRAM  AAiNG  THE  Z80 


known  in  advance.  Otherwise,  we  might,  for  example,  have  to  watch 
for  a  special  break  character,  and  stop  the  bit-serial  transfer  at  this 
point.  We  have  learned  to  do  that.  The  flowchart  for  this  program  ap- 
pears m  Figure  6.6.  The  program  appears  below: 


SERIAL 


LOOP 


LD 

LD 

LD 

iN 

BIT 

JR 

SRL 

RL 

JR 


C,  0 

A,  (COUNT) 

B,  A 

A,  (INPUT) 
7,  A 

Z,  LOOP 
A 

C 

NC,  LOOP 


CLEAR  INPUT  WORD 
LOAD  B  WITH  BYTE  COUNT 

READ  PORT 

BIT  7  IS  STATUS,  BIT  0  IS  DATA 
WAIT  FOR  A  "1" 
SHIFT  DATA  BIT  INTO  CARRY 
SAVE  INPUT  B  INTO  C 
CONTINUE  UNTIL  8  BITS  IN 


POLLING  OR  SERVICE  REQUEST 


READ  WORD  COUNT 


NO 


NO 


STORE  WORD 
RESET  BIT  COUNTER 
DECREMENT  WORD  COUNT 


NO 


DONE 


Fig.  6.6:  Bit  Serial  Transfer— Flowchart 
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PUSH   BC  SAVE  WORD  IN  STACK 

LD       C,  OIH  RESET  MARKER  BIT 

DEC     B  DECREMENT  BYTE  COUNTER 

JR        NZ,  LOOP      ASSEMBLE  NEXT  WORD 
This  program  has  been  designed  for  efficiency  and  will  use  new  lech- 
niques  which  we  wii!  explain  (see  Fig.  6.7). 

The  conveniions  are  ihe  following:  memory  locanon  COUNT  is  as- 
sumed lo  coniain  a  counl  of  the  number  of  words  lo  be  transferred. 
Register  C  will  be  used  to  assemble  eight  con.secuttve  bus  coming  in. 
Address  INPUT  refers  to  an  mput  register.  It  is  assumed  that  bit  posi- 
tion 7  of  this  register  is  a  status  flag,  or  a  clock  bit.  When  it  is  "0",  data 
IS  not  valid.  When  it  is  "1".  the  data  i.s  valid.  The  data  itself  will  be  as- 
sumed to  appear  m  bit  position  0  of  this  same  address,  in  many  in- 
stances, the  status  information  will  appear  on  a  different  register  than 
the  data  register.  It  .should  be  a  .simple  task,  then,  to  modify  this  pro- 
gram accordingly.  In  addition,  we  wii!  assume  that  the  first  bit  of  data 
to  be  received  by  this  program  is  guaranteed  to  be  a  "I",  It  indicates 
that  the  real  data  follows.  If  this  were  not  the  ca.se,  we  will  later  .see  an 
obvious  modification  to  take  care  of  H.  The  program  corresponds  ex- 
actly to  the  flowchart  of  Fig.  6.6,  The  first  few  lines  of  the  program  im- 
plement a  waiting  loop  which  tests  whether  a  bit  is  ready.  To  determme 
wheiher  a  bit  is  ready,  we  read  the  input  register,  then  test  the  zero  bit 
(Zl.  As  long  as  this  bit  is  "0",  the  mstruction  JR  will  succeed,  and  we 
will  branch  back  to  the  loop.  Whenever  the  status  (or  clock)  bit 
becomes  true  ("i"),  then  JR  willfail  and  the  next  instruction  will  be 
executed. 

This  initial  sequence  of  instructions  corresponds  to  arrow  1  in  Fig, 
6.7, 

Ai  this  point,  the  accumulator  contains  a  "I"  in  bit  position  7  and 
the  aciual  data  bu  m  bit  position  0.  The  first  data  bit  to  arrive  is  going 
to  be  a  "TV  However,  the  foUowmg  bits  may  be  either  "0"  or  "  I":  We 
now  wish  to  preserve  the  data  bit  which  has  been  collected  in  position  0. 
The  mstruction: 

SRL  A 

shifts  the  contents  of  the  accumulator  right  by  one  position.  This  causes 
the  right-most  bit  of  A,  which  is  our  data  bit,  to  fall  into  the  carry  bit. 
We  will  now  preserve  this  data  bit  into  register  C  (this  process  is  illus- 
trated by  arrows  2  and  3  m  Fig.  6.7): 

RL  C 
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® 


® 


© 


© 


STATUS 

OB 
CLOCK 


SERIAl 
DATA 
IN 


Fig.  6.7:  Seriai-lo-Parallei;  The  Registers 


The  effect  of  this  instruction  is  to  read  the  carry  bit  into  the  right-most 
bu  position  of  C.  At  the  same  time,  the  left-most  bit  of  C  fails  into  the 
carry  bit.  (If  you  have  any  doubts  about  the  rotation  operation,  refer  to 
Chapter  4!) 

It  is  important  to  remember  that  a  rotation  with  carry  operation  will 
both  save  the  carry  bit,  here  into  the  right-most  bit  position,  and  aiso 
recondition  the  carry  bit  with  the  value  of  bit  7  (or  bit  0). 

Here,  a  "0"  will  fall  mto  the  carry.  The  next  instruction: 

JR     NC.  LOOP 

icsis  the  carry  and  branches  back  to  address  LOOP  as  long  as  the  cmy 
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IS  "0".  This  IS  our  automatic  bit  counter.  It  can  readily  be  seen  that,  as  a 
result  of  the  first  RL,  C  wiii  contain  "00000001".  Eight  shifts  later,  ihe 
'M  "  will  finally  fall  into  the  carry  bit  and  stop  the  branching.  This  is  an 
ingenious  way  to  implement  an  automauc  loop  counter  without  having 
to  waste  an  insiruciion  to  decrement  the  contents  of  an  index  register. 
Thi.s  technique  is  used  in  order  to  shorten  the  program  and  improve  its 
performance. 

When  JR  NC  finally  fails,  8  bits  will  have  been  a.ssembled  into  C. 
This  value  should  be  preserved  in  the  memory.  Tills  is  accomplished  by 
the  next  insiruciion  (arrow 4  on  Fig.  6.7): 

PUSH  BC 

We  arc  here  saving  the  conienis  of  B  and  C  into  the  stack.  Saving  mto 
the  Slack  ls  po.ssible  only  if  there  is  enough  room  in  the  stack.  Provided 
that  this  condition  is  met,  it  is  usually  the  fastest  way  to  preserve  a  word 
in  the  memory,  even  though  we  save  an  unnecessary  register  (B).  The 
stack  pointer  is  updated  automatically.  If  w'c  were  not  pushing  a  word 
in  the  stack,  we  would  have  to  u.se  one  more  instruction  to  update  a 
memory  poinser.  We  could  equivalently  perform  an  indexed  addressing 
operaiion,  bui  that  would  also  involve  decrementing  or  incrementing 
the  index,  using  extra  time. 

After  !he  firsi  word  of  data  has  been  saved,  there  is  no  longer  any 
guarantee  ?hat  the  first  data  bu  lo  come  in  will  be  a  " ! ".  It  can  be  any- 
thing. We  must,  therefore,  reset  the  consents  lo  "00000001"  so  that  we 
can  keep  using  il  as  a  bit  counter.  Thi.s  is  performed  by  (he  next  instruc- 
tion: 

LD    C,  OiH 

Finally,  we  will  decrement  the  word  counter,  since  a  word  has  been 
a.ssemb!ed,  and  test  whether  we  have  reached  the  end  of  the  transfer. 
This  IS  accomplished  by  the  next  two  insiruciions: 

DEC  B 

JR     NZ,  LOOP 

The  above  program  has  been  designed  for  speed,  so  that  one  may 
capture  a  fast  input  stream  of  data  bits.  Once  the  program  terminates, 
it  is  naturally  advisable  to  immediately  read  away  from  the  stack  the 
words  that  have  been  saved  there  and  transfer  them  elsewhere  into  the 
memory.  We  have  already  learned  lo  perform  such  a  block  transfer  in 
Chapter  2. 
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Exercise  6.6:  Coiupiile  Ihe  niaxiniuiii  speed  ai  wluch  ihis  program  will 
be  able  to  read  serial  bi(s.  Look  up  ihe  number  of  cycles  required  by 
every  mstrudion  in  the  table  at  she  end  of  this  book,  then  compute  the 
time  which  will  elapse  during  execution  of  this  program.  To  compute 
the  length  of  tune  which  will  be  used  by  a  loop,  simply  multiply  the 
total  duration  of  this  loop,  expressed  in  microseconds,  by  the  number 
of  limes  It  will  be  executed.  Also,  when  computing  the  maximum  speed, 
assume  that  a  data  hit  will  be  ready  every  time  that  the  input  locution  is 
sensed. 

This  program  is  more  difricuit  lo  understand  than  the  previous  ones. 
Lei  us  look  at  it  again  (refer  to  Fig.  6.6)  in  more  detail,  examining  some 
trade-olTs. 

A  bit  of  data  comes  into  bu  position  0  of  "INPUT"  from  time  to 
time.  There  might  be,  i"or  example,  three  "Is"  in  succession.  We  must, 
therefore,  differentiate  between  the  successive  bits  coming  in.  This  is 
the  function  of  the  "clock"  signal. 

The  clock  (or  STATUS)  signal  tells  us  that  the  input  bit  is  now  valid. 
Before  reading  a  bu,  we  will  therefore  first  test  the  status  bit.  If  tlie 
status  is  "0",  we  must  wait.  If  U  is  "i",  then  the  data  bil  is  good. 

We  assume  here  that  the  status  signal  is  connected  to  bit  7  of  register 
INPUT. 

Exercise  6. 7:  Con  you  e.xplatn  why  bit  7  is  used  for  status,  and  bil  0  for 
data?  Does  It  matter? 

Once  we  have  captured  a  data  bit,  we  want  to  preserve  u  in  a  safe 
location,  then  shift  it  left,  so  that  we  can  get  the  next  bit. 

Unfortunately,  the  accumulator  is  ased  to  read  and  test  both  data 
and  status  in  this  program.  If  we  were  lo  accumulaie  data  in  the  accu- 
mulator, bit  position  7  would  be  erased  by  the  status  biL 

Exercise  6.H:  Can  you  sugge.^1  a  way  lo  lesi  status  without  erasing  the 

canK'tiis  oj  ihe  accuiuulator  (a  special  iiistructioii}?  If  ihis  can  be  done, 
could  we  use  the  accumulator  to  accunnilate  the  successive  bits  coming 
m?  Can  you  improve  speed  by  using  an  "automated  jump"? 

E.xercise  6.9:  Rewrite  the  program,  using  ihe  accumulator  to  store  the 
bus  coming  in.  Compare  it  to  the  previous  one  in  terms  of  speed  and 
number  of  instructions. 

Let  us  address  two  more  possible  vanatioas. 

We  have  a.ssumed  thai,  in  our  particular  example,  the  very  first  bit  to 
come  m  would  be  a  special  signal,  guaranteed  to  be  "1",  However,  in 
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general,  il  may  be  anything. 

Exercise  6.10:  ModiJ'y  ihe  pragra/n  above,  assiumug  iluti  ihe  very  first 
bu  lo  come  ui  is  valid  daia  (noi  to  be  discarded),  and  can  iJe  "0"  or 
"/",  Hint:  our  "bit  counter"  should  still  work  correctly,  if  you  initial- 
ize 11  with  the  correct  value. 

Finally,  we  have  been  saving  ihe  assembled  word  in  the  stack,  to  gam 
lime.  We  could  naturally  save  it  m  a  specified  memory  area. 

Exercise  6.  II:  Modify  tlw  progratu  above,  and  save  the  assembled  word 
in  the  meinorv  area  startmfi  at  BASE, 

Exercise  6. 12:  Modify  the  proKfum  alwve  so  thai  the  transfer  will  stop 
when  the  character  "S"  is  detected  in  the  input  stream. 

The  Hardware  Allernalivc 

As  usual  for  most  standard  n^put/ouipiit  aigorithm.s,  it  is  possible  lo 
implement  this  procedure  by  hardware.  The  chip  is  called  a  UART_  it 
wili  auioniatically  accumulaie  ihe  bits.  However,  when  one  wishes  lo 
reduce  the  componciH  count,  this  program,  or  a  variation  of  il,  will  be 
used  liisiead. 

Exercise  6. 13:  Modify  the  proiiraiii,  assuiitin^  lluil  data  is  available  in  bil 

posiuon  0  of  locafion  INPUT,  ^i^^  slaius  mjommlm  is  miikible 
in  bil  position  0  of  address  INPUT  +  /. 

BASIC  i/O  SUMMARY 

We  have  now  learned  to  perform  elementary  mpul/oulpul  opera- 
lions  as  well  as  to  manage  a  stream  of  parallel  data  or  .serial  bits.  We  are 
now  ready  to  communicate  with  real  inpul/output  devices. 

COMMUNICATING  WITH  INPUT/OUTPUT  DEVICKS 

In  order  lo  exchange  daia  with  inpul/oulpul  devices,  we  will  first 
have  io  ascertain  whether  data  is  available,  if  we  want  to  read  il;  or 
whether  the  device  is  ready  to  accept  data,  if  we  want  to  send  it.  Two 
procedures  may  be  used:  handshakmg  arsd  interrupts.  Let  us  study 
handshaking  first. 

Handshaking 

Handshakmg  is  generally  used  to  communicate  between  any  two 
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H£Gl5r£f! 


DATA 


OUTPUT 
DEVICE 


Fig.  6.8:  Handshaking  (Output) 


asynchronous  devices,  i.e.,  between  any  two  devices  which  are  not  syn- 
chronized. For  example,  if  we  want  to  send  a  word  so  a  parallel  printer, 
we  must  first  make  sure  that  the  input  buffer  of  this  printer  is  available. 
We  will,  therefore,  ask  the  printer:  Are  you  ready?  The  printer  will  say 
"yes"  or  "no."  If  it  is  not  ready  we  will  wait.  If  it  is  ready,  we  will  send 
the  data  (.see  Fig.  6.8). 


Fig.  6.8a:  Handshaking  (Input) 


Conversely,  before  reading  data  from  an  input  device,  we  will  verify 
whether  the  data  is  valid.  We  will  ask;  "Is  data  valid?"  And  the  device 
will  tell  us  "yes"  or  "no."  The  "yes  or  no"  may  be  indicated  by  status 
bits,  or  by  other  means  (see  Fig.  6.8a). 

As  an  analogy,  whenever  you  wish  to  exchange  information  with 
someone  who  i.s  independent  and  might  be  doing  something  else  at  ihe 
time,  you  should  ascertain  ilmi  he  is  ready  to  communicate  wish  you. 
The  usual  rule  of  courtesy  is  to  shake  his  hand.  Data  exchange  may  then 
follow.  This  IS  the  procedure  normally  used  in  commumcaiing  with  in- 
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pui/output  devices. 
Lei  us  now  illustrate  this  procedure  with  a  simple  exampie. 

Sending  a  Choracler  To  The  Printer 

The  character  will  be  assumed  to  be  coniained  in  memory  location 
CHAR.  The  program  to  prpni  a  appears  below: 

WAIT 


IN 

A,  (STATUS) 

BIT 

7,  A 

TEST  IF  READY 

JR 

Z,  WAIT 

OTHERWISE  WAIT 

LD 

A.  (CHAR) 

GET  CHARACTER 

OUT 

(PRNTD),  A 

PRINT  IT 

JR 

WAIT 

GO  FOR  NEXT 

The  print  program  i.s  straightforward  and  uses  the  handshaking  pro- 
cedure which  has  been  described  above.  The  data  paths  are  shown  m 
Figure  6.9 . 


CHAS 


DATA 


MEMORY  Z80 

Fig.  6.9:  Printer— Data  Paths 


STATUS 


PRNTD 


PRINTER 


The  character  (called  DATA)  is  iocated  at  memory  location  CHAR. 
First,  the  status  of  the  printer  is  checked.  Whenever  bit  7  of  the  status 
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register  becomes  1,  it  indicates  that  the  printer  ready  for  input,  i.e.,  its 
input  buffer  is  available.  At  this  point,  the  character  is  loaded  into 
the  accumulaior,  ihcn  ouipui  la  ihe  prinicr,  via  the  accumulator.  As 
long  as  ihc  status  bit  remains  0,  the  program  wil!  remain  m  a  loop, 
called  W.MT  in  ihc  program. 

Exercise  6.14:  How  many  instructions  would  be  saved  in  the  above  pro- 
gram by  loading  data  directly  mto  register  C  as  well  as  outputing  the  con- 
tents of  register  C  directly? 

Exercise  6. 15:  When  using  an  (iclual  printer,  u  ts  usually  necessary  lo 
send  a  siart  order  before  using  ihe  device.  Modify  this  program  to  gen- 
erate  such  cm  order,  assunung  ihai  the  siart  command  is  obtained  by 
wniing  a  1  in  hit  position  0  of  the  STA  TUS  register,  which  is  assumed 
to  be  bidirectional. 

Exercise  6J6:  If  the  BiT  instruction  were  not  available,  could  you  use 
another  instruction  instead,  in  line  2  of  the  program?  If  so,  explain  the 
advantage  of  using  the  BIT  instruction,  if  any. 

Exercise  6.17:  Modify  the  program  above  (a  print  a  string  of  n  charac- 
ters, where  n  will  be  assumed  to  be  less  than 

Exercise  6. 18:  Modify  the  above  program  to  print  a  string  of  characters 
until  a  "carnage-return  "  code  ts  encountered. 

Let  us  now  complicate  the  ouipul  procedure  by  requiring  a  code  con- 
version and  by  outputting  to  several  devices  at  a  time: 


Output  To  u  Seven-Segment  LED 

A  tradiiionat  seven-segmeni  iighl-emitting  diode  (LED)  may  display 
the  digits  "0"  through  "9",  or  even  "0"  through  "F"  hexadecimal  by 
lighting  combinations  of  its  7  segments.  A  .seven-segment  LED  is  shown 
m  Figure  6.!0.  The  characters  ihai  may  be  generated  with  this  LED 
appear  m  Figure  6.1 1. 

The  segments  of  an  LED  are  labeled  "a"  through  "g"  m  Figure  6.10. 

For  example,  "0"  wil!  be  displayed  by  lightmg  the  segments  abcdef. 
Lci  us  assume,  now,  that  bis  "0"  of  an  output  port  is  connected  lo  seg- 
ment "a",  that  "1"  is  connected  to  segment  "b",  and  so  on.  Bit  7  is 
not  used.  The  bmary  code  required  K)  light  up  fedcba  (to  display  "0") 
IS,  therefore,  "01  111  1 !"-  In  hexadecimal  this  is  "3F",  Do  the  follow- 
ing exercise. 


480 


INPUT/OUTPUT  TECHNIQUES 


B 


C 


Fig.  6.10;  Seven-Segmcn(  LED 
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Fig.  6.11:  Hexadecimal  Characters  Generated 
with  a  Seven-Segment  LED 
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Exercise  6.19:  Compute  the  seven-segment  equivalent  for  the  hexadeci- 
mal digits  "0"  through  "f".  Fill  out  the  table  below: 


Hex 

LED  code 

Hex 

LED  code 

Hex 

LED  code 

Hex 

LED  code 

0 

3F 

4 

8 

C 

1 

5 

9 

D 

2 

6 

A 

E 

3 

7 

B 

F  1 

Let  us  now  display  hexadecimal  values  on  several  LED's. 

Driving  Multiple  LED's 

An  LED  has  no  memory.  It  will  display  the  data  only  as  long  as  its 
segment  lines  are  active.  In  order  to  keep  the  cost  of  an  LED  display 
low,  the  microprocessor  will  display  mformation  on  each  of  the  LED's 
in  turn.  The  rotation  between  the  LED's  must  be  fast  enough  so  that 
there  is  no  apparent  blinking.  This  implies  that  the  time  spent  from  one 
LED  to  the  next  is  less  than  iOO  milliseconds.  Let  us  design  a  program 
which  will  accomplish  this.  Register  C  will  be  used  to  point  to  the  LED 
on  which  we  want  to  display  a  digit.  The  accumulator  is  assumed  to 
contain  the  hexadecimal  value  to  be  displayed  on  the  LED.  Our  first 
concern  is  to  convert  the  hexadecimal  value  into  its  seven-segment  rep- 
resentation. In  the  preceding  section,  we  have  built  the  equivalence 
table.  Since  we  are  accessing  a  table,  we  will  use  the  indexed  addressing 
mode,  where  the  displacement  index  will  be  provided  by  the  hexadeci- 
mal value.  This  means  that  the  seven-segment  code  for  hexadecimal 
digit  "3"  is  obtained  by  looking  up  the  third  element  of  the  table  after 
the  base.  The  address  of  the  base  will  be  called  SEGBAS,  The  program 
appears  below: 

LEDS 


£,  At 

A  CONTAINS  HEX  DIGIT 

LD 

D,  0 

USE  "DE"  AS  DISPLACEMENT 

LD 

HL,  SEGBAS 

USE  "HL"  AS  INDEX 

ADD 

HL,  DE 

TABLE  ADDRESS 

LD 

A,  {HLJ 

READ  CODE  FROM  TABLE 

LD 

B,  50H 

DELAY  VALUE  -  ANY 

LARGE  NBR 

OUT 

(C),  A 

OUTPUT  FOR  SET  DURATION 

DEC 

B 

DELAY  COUNTER 
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JR  NZ,  DELAY       KEEP  LOOPING 

LD        A,  C  C  IS  PORT  NUMBER 

DEC  C 

CP        MINLED  DONE  FOR  LAST  LED? 

JR         NZ,  OUT 

LD         BC,  (MAXLED)  IF  SO,  RESET  C  TO  TOP  LED 
OUT  RET 

The  program  assumes  that  register  C  contains  the  address  of  the  LED 
to  be  illuminated  next,  and  that  the  accumulator  A  contams  the  digit  to 
be  displayed. 

The  program  first  looks  up  the  seven-segment  code  corresponding  to 
the  hexadecimal  value  contained  in  the  accumulator.  Registers  D  and  E 
are  used  as  a  displacement  field,  and  registers  H  and  L  are  used  as  a 
16-bit  index  register.  The  hexadecimal  digit  is  added  to  the  base  address 
of  the  table: 

LEDS      LD       E,  A  7-SEGMENT  CODE 

LD       D,  0 
LD       HL,  SEGBAS 
ADD     HL.  DE 

A  delay  loop  is  then  implemented,  so  that  the  code  obtained  from  the 
table  is  displayed  for  an  appropriate  duration.  Here  the  constant  "50" 
hexadecimal  has  been  arbitrarily  chosen: 

LD       A,  (HL)  READ  CODE  FROM  TABLE 

LD       B,  50H  DELAY  VALUE 

The  delay  is  accomplished  usmg  a  classic  delay  loop.  The  first  instruc- 
tion: 

DELAY    OUT       (C),  A 

outputs  the  contents  of  the  accumulator  at  the  I/O  port  pointed  to  by 
register  C  (the  LED  number}.  The  next  two  instructions  implement  the 
delay  loop: 

DEC  B 

JR        NZ,  DELAY 
Once  the  delay  has  been  implemented,  we  must  simply  decrement  the 
LED  pointer,  and  make  sure  that  we  loop  around  to  the  highest  LED 
address  if  the  smallest  LED  address  has  been  reached: 

LD  A.C 
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DEC  C 
CP  MINLED 
JR        NZ,  OUT 
LD       BC,  (M AXLED) 
OUT  RET 

It  is  assumed  here  that  the  above  program  has  been  written  as  a  sub- 
rouiine,  and  the  last  instruction  is  then  RET:"return  from  subroutine" 


Exercise  6.20:  It  is  usually  necessary  to  turn  off  the  segment  drivers  for 
the  LED  prior  to  displaying  the  digit.  Modify  the  above  program  by 
adding  the  necessary  instructions  (output  "00"  as  tlie  character  code 
prior  to  outpufimg  the  cluiracler). 

Exercise  6.21:  Wliat  would  liappen  to  the  display  if  the  DELA  Y  label 
were  moved  up  by  one  line  position?  Would  this  change  the  tuning? 
Would  this  change  the  appearance  of  the  display? 

Exercise  6.22:  You  will  notice  that  the  first  four  instructions  of  the  pro- 
gram are,  in  fact,  performing  a  16-bit  Indexed  memory  access.  How- 
ever, It  seems' clumsy,  without  using  the  mde.xmg  mechanism.  Assume 
that  the  SEC B AS  address  is  known  m  advance.  Call  SEGBSH  the 
high-order  part  of  this  address,  and  SEGBSL  the  low  part  of  this  ad- 
dress. Store  SEGBSH  in  the  high-order  part  of  the  IX  register.  Now 
write  the  above  program,  using  the  Z80  index-addressing  mechanism, 
and  using  SEGBSL  as  the  displacement  field  of  the  instrucion.  What 
are  the  advantages  and  disadvantages  of  this  approach? 

E.xercise  6.23:  Assuming  that  the  above  program  is  a  subroutine,  you 
will  notice  that  it  uses  registers  B,  D,  E,  H  and  L  internally,  and  modi- 
fies their  contents.  If  the  subroutine  may  freely  use  the  memory  area 
designated  by  address  Tl,  T2,  T3,  T4,  T5,  could  you  add  instructions  at 
the  beginning  and  at  the  end  of  this  program  which  will  guarantee  that, 
when  the  subroutine  returns,  the  contents  of  registers  B,  D,  E,  H  and  L. 
will  be  the  same  as  when  the  subroutine  was  entered? 

Exercise  6.24:  Same  exercise  as  above,  but  assume  that  the  memory 
area  TI,  etc.,  is  not  available  to  the  subroutine.  (Hint:  remember  that 
there  is  a  built-in  mechanism  in  every  computer  for  preserving  informa- 
tion in  a  chronological  order.) 

"We  have  now  solved  common  mput/output  problems.  Let  us  con- 
sider the  case  of  a  common  peripheral:  the  Teletype, 
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Teletype  Input-Output 


The  Teletype  is  a  serial  device.  It  both  sends  and  receives  words  of  in- 
formation in  a  senai  format.  Each  character  is  encoded  m  an  8-bit 
ASCII  format  (the  ASCII  table  appears  at  the  end  of  this  book}.  In  ad- 
dition, every  character  is  preceded  by  a  "start"  bit,  and  terminated  by 
two  "slop"  bus.  In  the  so-called  20-milliamp  current  loop  interface, 
which  is  most  frequently  used,  the  state  of  the  line  is  normally  a  "1". 
This  is  used  to  indicate  to  the  processor  that  the  line  has  not  been  cut.  A 
start  is  a  "r'-to--"0"  transition.  It  indicates  to  the  receiving  device  that 
data  bits  follow.  The  standard  Teletype  is  a  lO-characters-per-second 
device.  We  have  just  established  that  each  character  requires  1 1  bits. 
This  means  that  the  Teletype  will  transmit  110  bits  per  second.  It  is  said 
to  be  a  1 10-baud  device.  We  will  design  a  program  to  serialize  bits  out 
to  the  Teletype  at  the  correct  speed. 


START  PUtSE 


MARK 


SPACE  


2  STOP  PUtSES 
STOP  I  ^  STOP  2  s 


10 


9.09  ms 


Fig.  6.12:  Format  of  a  Teletype  Word 

One-hundred-and-ten  bits  per  second  implies  that  bus  are  separated 
by  9.09  miitiseconds.  This  will  have  to  be  the  duration  of  the  delay  loop 
to  be  implemented  between  successive  bits.  The  format  of  a  Teletype 
word  appears  in  Figure  6.12.  The  flowchart  for  bit  input  appears  in 
Figure  6.13.  The  program  follows: 

TTYIN 


NEXT 


IN 

A,  (STATUS) 

BIT 

7,  A 

DATA  READY? 

JR 

Z,  TTYIN 

OTHERWISE  WAIT 

CALL 

DELAY] 

CENTER  OF  PULSE 

IN 

A,  (TTYBIT) 

START  BIT 

OUT 

(TTYBIT),  A 

ECHO  IT 

CALL 

DELAY9 

NEXT  PULSE  (9  MS) 

LD 

B,  08H 

BIT  COUNT 

IN 

A,  (TTYBIT) 

READ  DATA  BIT 

OUT 

(TTYBIT),  A 

ECHO  IT 

SRL 

A 

SAVE  IT  IN  CARRY 
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TTYiN 


YES 

WAIT  4.5  ms 
ECHO  START  BIT 

WAIT  9,09  ms 

SHIFT  IN  DATA  BIT 
ECHO  IT 

WAIT  13.59  ms 


Fig.  6.13:  TTY  Inpu(  with  Echo 
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RR 

C 

PRESERVE  IT  INTO  C 

CALL 

DELAY9 

NEXT  PULSE  (9  MS) 

DEC 

B 

DECREMENT  BIT  COUNT 

JR 

NZ,  NEXT 

IN 

A,  (TTYBIT) 

READ  STOP  BIT 

OUT 

(TTYBIT),  A 

ECHO  IT 

CALL 

DELAY9 

SKIP  SECOND  STOP 

RET 

Fig,  6.14:  Teletype  Program 

Let  us  examine  the  program  in  detaiL  First,  the  status  of  the  Teletype 
must  be  tested  to  determine  if  a  character  is  available: 

TTYIN  IN       A,  (STATUS) 

BIT       7,  A 
JR        Z.  TTYIN 
The  "BIT"  mstruction  is  a  useful  Z80  facility  which  allows  testing 
any  bit  in  any  data  register.  It  does  not  modify  the  contents  of  the  regis- 
ter under  test.  The  Z  flag  is  set  if  the  specified  bit  is  0,  and  reset  other- 
wise. 

This  program  will,  therefore,  loop  until  the  status  finally  becomes 
"1",  It  is  a  classic  polling  loop. 

Note  also  that,  smce  the  STATUS  does  not  need  to  be  preserved,  we 
could  advantageously  use 

AND  lOOOOOOOB 

instead  of 

BIT      7,  A 

However,  using  the  AND  instruction  destroys  the  contents  of  A 
{acceptable  here). 

When  optimizing  a  program,  remember  that  each  new  instruction 
may  introduce  side-effects. 

Next,  a  4.5  ms  delay  is  implemented  in  order  to  sense  the  start  bit  in 
the  middle  of  the  pulse. 

CALL  DELAY! 

where  DELAY  1  is  the  delay  subroutine  implementing  the  required 
delay.  The  first  bit  to  come  is  the  start  bit.  It  should  be  echoed  to  the 
Teletype,  but  otherwise  ignored.  This  is  done  by  the  next  instructions: 

TTYIN     IN        A,  (TTYBIT) 
OUT     (TTYBIT),  A 
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We  must  then  wait  for  ihe  first  data  bit.  The  necessary  delay  is  equal  to 
9.09  milliseconds  and  is  implemented  by  a  subrouime: 

CALL  DELAY9 
Register  B  is  used  as  a  counter  and  is  loaded  with  the  value  8  in  order  to 
capture  the  8  data  bits: 


LD 


B,  08H 


Next,  each  data  bit  will  be  read  in  turn  into  the  accumulator,  then 
echoed.  1(  is  assumed  to  arrive  in  bit  position  0  of  the  accumulator.  The 
data  bu  will  then  be  preserved  into  register  C,  where  u  will  be  shifted  m. 
The  transfer  from  A  to  C  is  performed  through  the  carry  bit: 
NEXT       IN        A,  (TTYBIT) 

OUT     (TTYBIT),  A 

SRL  A 

RR  C 

This  sequence  is  illustrated  in  Figure  6.15. 

A  I/O  SPACE 


COUNTER 


Fig.  6,15:  Teletype  Input 

Next,  the  usual  9  millisecond  delay  is  implemented,  the  bit-counter  is  dec- 
remented, and  the  loop  is  entered  again  as  long  as  the  eight  bus  have 
not  been  captured: 

CALL  DELAY9 
DEC  B 

JR        NZ,  NEXT 

Finally,  the  STOP  bit  is  captured,  and  echoed.  It  is  usually  sufficienl  to 
send  a  single  STOP  bit,  however  both  could  be  sent  back  using  two 
more  instructions: 

IN  A,  (TTYBIT) 

OUT  (TTYBIT),  A 

CALL  DELAY9 
RET 
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The  program  should  be  examined  with  attention.  The  logic  is  quite 
simple.  The  new  fact  is  that  whenever  a  bit  is  read  from  the  Teletype  (at 
address  TTYBIT),  it  is  echoed  back  to  the  Teletype.  This  is  a  standard 
feature  of  the  Teletype.  Whenever  a  user  presses  a  key,  the  information 
IS  transmitted  to  the  processor  and  then  back  to  the  printing  mechanism 
of  the  Teletype.  This  verifies  that  the  transmission  lines  are  working 
and  that  the  processor  is  operating  when  a  character  is,  indeed,  printing 
correctly  on  the  paper. 


ENTER 


ENTER 


SEflD  START 
BIT 


SEND  DATA 
BITS 


SEND  STOP 
BIT 

' 

EXIT 

SET  BIT 
COUNTER  TO 
ELEVEN 

 ^ 

OUTPUT 
A  BIT 

DELAY 
9,1  MSEC 

L--<r  DO 

Fig.  6.16;  Teletype  Output 


Exercise  6,25:  Wme  the  delay  routine  which  results  in  the  9.09  millisec- 
ond delay.  (DEL A  Y  subroutine) 

Exercise  6,26:  Using  the  example  of  the  program  developed  above, 
write  a  PRINTC  program  which  will  prmt  on  tlie  Teletype  the  contents 
of  memory  location  CHAR  (see  Fig.  6. 15). 

The  answer  appears  below: 


PRINTC    LD  B,  11 

LD  A,  (CHAR) 

OR  A 

RLA 


COUNTER  =  1!  BITS 

GET  CHARACTER 

CLEAR  CARRY  =  START  BIT 

CARRY  INTO  A 
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NEXT      OUT     (TTYBIT),  A  OUTPUT 
CALL  DELAY 

RRA  NEXT  BIT 

SCF  CARRY  =  1  (STOP  BIT) 

DEC     B  BIT  COUNT 

JR        NZ,  NEXT 

RET 

Register  B  is  used  as  a  bit  counter  for  the  transmission.  The  contents 
of  bit  0  of  A  will  be  sent  to  the  Teletype  line  ("TTYBIT").  Note  how 
the  carry  is  used  to  provide  a  ninth  bit  (the  START  bit).  Also,  note  that 
the  carry  is  cleared  by: 

OR  A 

At  the  end  of  the  program,  the  carry  is  set  to  one  by: 
SCF 

in  order  to  generate  a  stop  bit. 


Exercise  6.27:  Modify  the  program  so  ihai  u  wails  for  a  START  bii  in- 
stead of  a  STATUS  bi(. 

Printing  a  Siring  of  Characters 

We  will  assume  that  the  PRINTC  routine  (see  Exercise  6.26)  takes 
care  of  printing  a  character  on  our  printer,  or  display.or  any  output  de- 
vice. We  will  here  print  the  contents  of  memory  locations  (START)  to 
(START  -i-  N). 

The  program  is  straightforward  (see  Figure  6. 17): 


PSTRING 

LD 

B,  NBR 

LENGTH  OF  STRING 

LD 

HL,  START 

BASE  ADDRESS 

NEXT 

A,  (HL) 

GET  CHARACTER 

CALL 

PRINTC 

PRINT  IT 

INC 

HL 

NEXT  ELEMENT 

DEC 

B 

JR 

NZ,  NEXT 

DO  IT  AGAIN 

RET 

490 


INPUT/OUTPUT  TECHNIQUES 


MEMOfiy 


B  A 


COUNTER 


TO  PRINTER 


Fig.  6.17:  Printing  a  Memory  Block 


PERIPHERAL  SUMMARY 

We  have  now  described  the  basic  programming  techniques  used  to 
communicale  with  typical  input/outpul  devices.  In  addition  to  the  data 
transfer,  it  will  be  necessary  to  condition  one  or  more  control  registers 
Within  each  I/O  device  in  order  to  condition  the  transfer  speeds,  the  in- 
terrupt mechanism,  and  the  various  other  options  correctly.  The  man- 
ual for  each  device  should  be  consulted.  (For  more  details  on  the  spe- 
cific algorithms  for  exchanging  information  with  all  the  usual  peripher- 
als, the  reader  is  referred  to  our  book,  C207,  Microprocessor  huerfac- 
ing  Techniques. ) 

We  have  now  learned  to  manage  single  devices.  However,  in  a  real 
system,  all  peripherals  are  connected  to  the  buses  ,  and  may  request 
service  simultaneously.  How  are  we  going  to  schedule  the  processor's 
time? 

l.NPUT/OUTPUT  SCHEDULING 

Since  input/output  requests  may  occur  simultaneously,  a  scheduling 
mechanism  must  be  implemented  in  every  system  to  determine  in  which 
order  service  will  be  granted.  Three  basic  input/output  techniques  are 
used,  which  can  be  combined  with  each  other.  They  are:  polling,  inter- 
rupt, DMA,  Polling  and  interrupts  will  be  described  here.  DMA  is 
purely  a  hardware  technique,  and  as  such  will  not  be  described  here,  (it 
is  covered  m  the  reference  books  C20]  and  C207.) 
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Polling 

Conceptually,  polling  is  the  simplest  method  for  managing  multiple 
peripherals.  With  this  strategy,  the  processor  interrogates  the  devsces 
connected  to  the  buses  in  turn.  If  a  device  requests  service,  the  service 
IS  granted.  If  it  does  not  request  service,  the  next  peripheral  is  exam- 
ined. Polling  IS  used  not  just  for  the  devices,  but  for  any  device  service 
routine. 

As  an  example,  if  the  system  is  equipped  with  a  Teletype,  a  tape  re- 
corder, and  a  CRT  display,  the  polling  routine  would  interrogate  the 
Teletype:  "Do  you  have  a  character  to  transmit?"  It  would  interrogate 
the  Teletype  output  routine,  asking:  "Do  you  have  a  character  to 
send?"  Then,  assuming  that  the  answers  are  negative  so  far,  it  would 
mterrogate  the  tape-recorder  routines,  and  finally  the  CRT  display.  If 
only  one  device  is  connected  lo  a  system,  polling  will  be  used  as  well  to 
determine  whether  it  needs  service.  As  an  example,  the  flowcharts  for 
reading  a  paper-tape  reader  and  for  printing  on  a  printer  appear  in  Fig- 
ures 6.20  and  6.21 . 


MPU 


0 


HOLD 


MRU 


MEMORY 


DATA  BUS 


1 


i/O 


MEMORY 


i/O 


i  iKif  " 


MEMORY 


L. 


I/O 


i/O 


DZ 

I/O 


POtUNG 


INTERRUPT 


DMA 


Fig.  6.18:  Three  Methods  of  I/O  Control 
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Example:  a  polling  loop  for  devices  I,  2,  3,  4  (see  Fig,  6.19): 


P0LL4  IN 


A,  (STATUS  1)     GET  STATUS  OF  DEVICE  1 


BIT 

CALL 

IN 

BIT 

CALL 

IN 

BIT 

CALL 

IN 

BIT 

CALL 

JR 


7,  A 

NZ,  ONE 

A,  (STATUS2) 

7,  A 

NZ.  TWO 

A,  (STATUS3) 

7,  A 

NZ,  THREE 
A,  (STATUS4) 
7,  A 

NZ,  FOUR 
P0LL4 


SERVICE  REQUEST? 
BIT  7=1? 
DEVICE  2 


DEVICE  3 


DEVICE  4 


NO  REQUEST,  TRY  AGAIN 


Bit  7  of  the  status  register  for  each  device  is  "1"  when  it  wants  serv- 
ice. When  a  request  is  sensed,  this  program  branches  to  the  device 
handler,  at  address  ONE  for  device  1,  TWO  for  device  2,  etc, 

A  fine  point  is  worth  noting  here.  For  each  instruction,  it  is  impor- 
tant to  verify  carefully  the  way  in  which  it  affects  the  condition  codes. 
It  should  be  noted  that  the  IN  A  instruction  does  not  change  the  flags. 
If  an  IN  r  instruction  has  been  used  instead  of  an  IN  A  instruction,  bit  7 
of  the  input  would  automatically  be  reflected  as  the  SIGN  bit  in  the 
flags  register.  The  special  instruction  "BIT  7, A"  would  become  un- 
necessary. However,  because  the  IN  A  instruction  does  not  change  the 
flags,  this  extra  test  must  be  included  in  the  program. 

In  some  hardware  implementations,  input/output  devices  may  be 
treated  as  memory  devices  for  purposes  of  addressing.  This  ts  called 
memory-mapped  input/output.  In  this  case,  the  IN  mstruction  would 
be  replaced  by  an  LD  mstruction  and  the  rest  of  the  program  would  be 
as  above,  since  LD  does  not  affect  the  flags. 

The  advantages  of  polling  are  obvious:  il  is  simple,  does  not  require 
any  hardware  assistance,  and  keeps  all  input/output  synchronous  with 
the  program  operation.  Its  disadvantage  is  just  as  obvious:  most  of  the 
processor's  time  is  wasted  looking  at  devices  that  do  not  need  service. 
In  addition,  by  wasting  so  much  time,  the  processor  might  give  service 
to  a  device  too  late. 

Another  mechanism  is,  therefore,  desirable  m  order  to  guarantee  that 
the  processor's  time  can  be  used  to  perform  useful  computations  rather 
than  polling  devices  needlessly  all  the  time.  However,  let  us  stress  that 
polling  is  used  extensively  whenever  a  microprocessor  has  nothing  bet- 
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Fig.  6.19:  Polling  Loop  Flowchart 


SET  READER 
ENABLE  ON 


READ  CHARACTER 


Fig.  6.20:  Reading  from  a  Paper-Tape  Reader 
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YES 

LOAD  PUNCH 
OR  PRINTER 
BUFFER 

TRANSMIT 
DATA 

Fig.  6.21:  Printing  on  a  Punch  or  Printer 


ter  to  do,  as  it  keeps  the  overall  organization  simple.  Let  us  examine  the 
essential  alternative  to  polling:  interrupts. 


Interrupts 

The  concept  of  interrupts  is  illustrated  in  Figure  6.18.  A  special  hard- 
ware line,  the  interrupt  line,  is  connected  to  a  specialized  pin  of  the  mi- 
croprocessor. Multiple  input/output  devices  may  be  connected  to  this 
interrupt  line.  When  any  one  of  them  needs  service,  it  sends  a  level  or  a 
pulse  on  this  line.  An  interrupt  signal  is  the  service  request  from  an  in- 
put/output device  to  the  processor.  Let  us  examine  the  response  of  the 
processor  to  this  interrupt. 

In  any  case,  the  processor  completes  the  instruction  that  it  was  cur- 
rently executing;  otherwise,  this  would  create  chaos  inside  the  micro- 
processor. Next,  the  microprocessor  should  branch  to  an  interrupt-han- 
dling  routine  which  will  process  the  interrupt.  Branching  to  such  a  sub- 
routine implies  that  the  contents  of  the  program  counter  must  be  saved 
on  the  stack.  An  tmerrupt  must,  therefore,  cause  the  automatic  preser- 
vation of  the  program  counter  on  the  stack.  In  addition,  the  flag  regis- 
ter F  should  be  also  preserved  automatically,  as  its  contents  will  be 
altered  by  any  subsequent  instruction.  Finally,  if  the  interrupt-handllng 
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routine  should  modify  any  internal  registers,  these  internal  registers 
should  also  be  preserved  on  the  stack  (see  Figures  6.22  and  6.23). 


SP 


PCL 


PCH 


Fig.  6.22;  Z80  Stack  After  Interruption 


_D 

£ 

F 


Fig.  6.23:  Saving  Some  Working  Registers 

After  all  these  registers  have  been  preserved,  one  can  branch  to  the 
appropriate  interrupt-handling  address.  At  the  end  of  this  routine,  all 
the  registers  should  be  restored,  and  a  special  interrupt  return  should  be 
executed  so  that  the  mam  program  will  resume  execution.  Let  us  exam- 
ine in  more  detail  the  interrupt  lines  of  the  Z80. 

Z80  Interrupts 

An  interrupt  is  a  signal  sent  to  the  microprocessor,  which  may  re- 
quest service  at  any  time  and  is  asynchronous  to  the  program.  When- 
ever a  program  branches  to  a  subroutine,  such  branching  is  synchron- 
ous to  program  execution,  i.e.,  scheduled  by  the  program.  An  inter- 
rupt, however,  may  occur  at  any  time,  and  will  generally  suspend  the 
execution  of  the  current  program  {without  the  program  knowing  it). 
Because  it  may  happen  at  any  time  relative  to  program  execution,  it  is 
called  asynchronous. 

Three  interruption  mechanisms  are  provided  on  the  Z80:  the  bus  re- 
quest (BUSRQ),  the  non-maskable  interrupt  (NMI)  and  the  usual  inter- 
rupt (INT). 

Let  us  examine  these  three  types. 
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The  Bus  Request 

The  bus  request  is  the  highest  priority  interrupt  mechanism  on  the 
Z80.  The  mterrupt  sequence  for  the  Z80  is  shown  in  Figure  6.24.  As  a 
general  rule,  no  mterrupt  will  be  sensed  by  the  Z80  until  the  current 
machme  cycle  is  completed.  The  NMl  and  INT  mterrupts  will  not  be 
taken  into  account  until  the  current  mstruction  is  finished.  However, 
the  BUSRQ  will  be  handled  at  the  end  of  the  current  machme  cycle, 
without  necessarily  waiting  for  the  end  of  the  instruction.  It  is  used  for 


Fig.  6.24;  Interrupt  Sequence 
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a  direct  memory  access  (DMA),  and  will  cause  the  Z80  to  go  into  DMA 
mode  (see  ref.  C201  for  an  explanation  of  the  DMA  mechanism).  If  the 
end  of  an  instruction  has  been  reached,  and  if  any  NMI  or  INT  were 
pending,  they  would  be- memorized  internally  in  the  Z80  by  setting  spe- 
cialized flip-flops:  the  NMI  flip-flop,  and  the  INT  flip-flop.  In  DMA 
mode,  the  Z80  suspends  operation  and  releases  its  data-bus  and 
address-bus  in  the  high-impedance  state.  This  mode  is  normally  used  by 
a  DMA  controller  to  perform  transfers  between  a  high-speed  input- 
output  device  and  the  memory,  using  the  microprocessor  data-bus  and 
address-bus.  The  end  of  a  DMA  operation  is  indicated  to  the  Z80  by 
BUSRQ  changing  levels.  At  this  point,  the  Z80  will  resume  normal 
operation.  In  particular,  it  will  first  check  whether  its  internal  NMI  or 
INT  flip-flops  had  been  set  and,  if  so,  execute  the  corresponding  inter- 
rupts. 

The  DMA  should  normally  not  be  of  concern  to  the  programmer,  un- 
less timing  is  important.  If  a  DMA  controller  is  present  in  the  system, 
the  programmer  must  understand  that  the  DMA  may  delay  the 
response  to  an  NMI  or  an  INT. 

The  Non-Maskable  Interrupt 

This  type  of  interrupt  cannot  be  inhibited  by  the  programmer.  It  is 
therefore  said  to  be  non-maskable,  hence  its  name.  It  will  always  be  ac- 
cepted by  the  Z80  upon  completion  of  the  current  instruction,  assuming 
no  bus  request  was  received.  (If  an  NMI  is  received  during  a  BUSRQ, 
it  will  set  the  internal  NMI  flip-flop,  and  will  be  processed  at  the  end  of 
the  instruction  following  the  end  of  the  BUSRQ.) 

The  NMI  will  cause  an  automatic  push  of  the  program  counter  into 
the  stack  and  branch  to  address  0066H:  the  two  bytes  representing  the 
address  0066H  will  be  installed  in  the  program  counter.  They  represent 
the  start  address  of  the  handling  routine  for  the  NMI  (see  figure  6.25). 

This  interrupt  mechanism  has  been  designed  for  speed,  as  it  is  used  in 
case  of  "emergencies".  Therefore,  it  does  not  offer  the  flexibility  of  the 
maskable  interrupt  mode,  described  below. 

Note  also  that  an  interrupt  routine  must  have  been  loaded  at  address 
0066H  prior  to  using  the  NMI, 

NMI  will  first  cause: 


SP   SP  - 

(SP)   PCH 

SP   SP  - 

(SP)  ^  PCL 


i 


1 


push  PC 
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Fig.  6.25:  NMI  Forces  Automatic  Vectoring 

Then,  NMI  causes  an  automatic  restart  at  iocation  0066H.  The  com- 
plete sequence  of  events  is  the  following: 

PQ    STACK  (preserve  program  counserl 

IFFl   >■  IFF2  (preserve  IFF) 

0   »-  IFFl  (reset  IFF) 

JUMP  TO  0O66H  (execute  interrupt  handler) 

Also,  the  status  of  interrupt-mask-bit  flip-flop  (IFFl)  at  the  time  that 
NMI  was  received  is  preserved  automatically  mto  IFF2.  Then,  IFFl  is  re- 
set in  order  to  prevent  any  further  interrupts.  This  feature  is  important  to 
prevent  the  loss  of  lower-priority  INT's  and  simplifies  the  external  hard- 
ware; the  status  of  a  pending  INT  is  preserved  internally  in  the  Z80. 

The  NMI  interrupt  is  normally  used  for  high  priority  events  such  as  a 
real-time  clock  or  a  power  failure. 

The  return  from  an  NMI  is  accomplished  by  a  special  instruction,  RETN: 
"return  from  non-maskable  interrupt,"  The  contents  of  IFFl  are  restored 
from  IFF2,  and  the  contents  of  the  program  counter  PC  are  restored  from 
their  location  in  the  stack.  Since  IFFl  had  been  reset  during  execution 
of  the  NMI,  no  external  INT's  could  be  accepted  during  the  NMI 
(unless  the  programmer  uses  an  EI  instruction  within  the  NMI  routine); 
there  has  been  no  loss  of  information. 
Upon  termination  of  the  interrupt  handler,  the  sequence  is; 

1FF2   »"    IFFl  (restore  IFF) 

STACK  *     PC  (restore  program  counter! 

Note  that,  once  IFFl  is  restored,  maskable  interrupt  enable  status  is 
restored. 
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Interrupt 

The  ordinary,  maskable.interrupt  INT  may  operate  in  one  of  three 
modes.  They  are  specific  to  the  Z80,  as  the  8080  is  equipped  with  only  a 
single  interrupt  mode.  The  ordinary  interrupt  INT  may  also  be  masked 
seiectiveiy  by  the  programmer.  Settmg  the  interrupt  flip-flops  IFFl  and 
IFF2  to  a  "1"  will  authorize  interruptions.  Setting  them  to  a  "0" 
(masking  them)  will  prevent  detection  of  INT.  The  EI  instruction  is 
used  to  set  them,  and  the  DI  instruction  is  used  to  reset  them.  IFF!  and 
IFF2  are  set  or  reset  simultaneously.  Durmg  execution  of  the  EI  and  DI 
instructions,  INT's  are  disabled  in  order  to  prevent  any  loss  of  informa- 
tion. 

Let  us  now  examine  the  three  interrupt  modes: 
Interrupt  Mode  0 

This  mode  is  identical  to  the  8080  interrupt  mode.  The  Z80  will 
operate  in  interrupt  mode  0  either  when  initially  started  (when  the  RE- 
SET signal  has  been  applied)  or  else  when  an  IMO  instruction  has  been 
executed.  Once  mode  0  has  been  set,  an  interrupt  will  be  recognized  if 
the  interrupt  enable  flip-flop  IFFl  is  set  to  1,  provided  no  bus-request 
or  non-maskable  interrupt  occurs  at  the  same  time.  The  interrupt  will 
be  detected  only  at  the  end  of  an  instruction.  Essentially,  the  Z80  will 
respond  to  the  interrupt  by  generating  an  lORQ  (and  an  Ml  signal), 
and  then  do  nothing,  except  wait. 

It  is  the  responsibility  of  an  external  device  to  recognize  the  lORQ 
and  Ml  (this  is  called  an  interrupt  acknowledge  or  INTA)  and  to  place 
an  instruction  on  the  data-bus.  The  Z80  expects  an  instruction  to  be 
placed  on  its  data  bus  by  the  external  device  within  the  next  cycle.  Typi- 
cally, an  RST  or  a  CALL  instruction  is  placed  on  the  bus.  Both  of  these 
instructions  automatically  preserve  the  program-counter  in  the  stack, 
and  cause  branching  to  a  specific  address.  The  advantage  of  the  RST  in- 
struction is  that  it  resides  within  a  single  byte,  i.e.,  it  executes  rapidly. 
Its  disadvantage  is  to  branch  to  only  one  of  eight  possible  locations  in 
page  zero  (addresses  0  through  255).  The  advantage  of  the  CALL  in- 
struction is  that  it  is  a  general-purpose  branch  instruction  which  speci- 
fies a  full  16-bit  address.  However,  it  requires  three  bytes  and  therefore 
executes  less  rapidly. 

Note  that  once  the  interrupt  processing  starts,  all  further  interrupts 
are  disabled.  IFFl  and  IFF2  are  automatically  set  to  "0",  It  is  then  the 
responsibility  of  the  programmer  to  insert  an  EI  instruction  (Enable  In- 
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terrupts)  at  the  appropriate  location  within  his  program  if  he  wishes  to 
enable  interrupts,  and,  in  any  case,  before  returning  from  the  interrupt. 

The  detailed  sequence  corresponding  to  the  mode  0  mterrupt  is 
shown  in  Figure  6.26. 
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Fig.  6,26:  Interrupt  Modes 


The  return  from  the  interrupt  is  accomplished  by  an  RETI  instruc- 
tion. Let  us  remind  the  programmer  at  this  point  that  he/she  is  usually 
responsible  for  explicitly  clearing  the  interrupt  which  has  been  serviced 
on  the  I/O  device,  and  always  for  restormg  the  interrupt  disable  flag  in- 
side the  Z80.  However,  the  peripheral  controller  may  use  the  INTA  sig- 
nal to  clear  the  INT  request,  thus  freemg  the  programmer  of  this  chore. 

in  addition,  should  the  interrupt-handiing  routine  modify  the  con- 
tents of  any  of  the  internal  registers,  the  programmer  is  specifically  re- 
sponsible for  preserving  these  registers  in  the  stack  prior  to  executing 
the  mterrupt-handling  routine.  Otherwise,  the  contents  of  these  regis- 
ters will  be  destroyed,  and  when  the  interrupted  program  resumes  exe- 
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cution,  it  wiil  fail.  For  example,  assuming  that  registers  A,  B,  C,  D,  E, 
H  and  L  will  be  used  withm  the  interrupt  handler,  they  will  have  to  be 
saved  (see  Figure  6.27), 


PCL 


FCH 


STACK 


DECREASING 
ADDRESSES 


Fig.  6,27:  Saving  the  Registers 


The  corresponding  program  is: 

SAVREG  PUSH  AF 
PUSH  BC 
PUSH  DE 
PUSH  HL 

Upon  completion  of  the  interrupt-handling  routine,  these  registers  must 
be  restored.  The  interrupt  handier  will  terminate  with  the  following  se- 
quence of  instructions: 

FOP  HL 
POP  DE 
POP  BC 
POP  AF 

EI  (unless  El  was  used  earlier  in 

the  routine) 

Additionally,  if  registers  IX  and  lY  are  used  by  the  routine  they  must 
also  be  preserved,  then  restored. 
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Interrupt  Mode  I 

This  interrupt  mode  is  set  by  executing  the  I  Ml  instruction.  It  is  an 
automated  interrupt  handler  which  causes  an  automatic  branch  to  loca- 
tion 0038H.  It  is  therefore  essentially  analogous  to  the  NMI  interrupt 
mechanism  except  that  it  may  be  masked.  The  Z80  automatically  pre- 
serves the  contents  of  PC  into  the  stack  (see  Figure  6.28). 
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Fig.  6.28:  Mode  1  Interrupl 


This  automated  interrupt  response,  which  "vectors"  all  interrupts  to 
memory  location  38H,  stems  from  the  early  8080' s  requirement  to 
minimize  the  amount  of  external  hardward  necessary  for  using  inter- 
rupts. Its  possible  disadvantage  is  to  cause  a  branch  to  a  single  memory 
location.  In  case  several  devices  are  connected  to  the  INT  line,  the  pro- 
gram starting  at  location  38H  will  be  responsible  for  determining  which 
device  requested  service.  This  problem  will  be  addressed  below. 

One  precaution  must  be  taken  with  respect  to  the  timing  of  this  inter- 
rupt: when  performing  programmed  input/output  transfers,  the  Z80 
will  ignore  any  data  that  may  be  present  in  the  data  bus  during  the  cycle 
which  follows  the  interrupt  (the  mterrupt  acknowledge  cycle). 
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Interrupt  Mode  2  (Vectored  Interrupts) 

This  mode  is  set  by  executing  an  IM2  instruction.  It  is  a  powerful 
mode  which  allows  automatic  vectoring  oF  interrupts.  The  interrupt 
vector  IS  an  address  supplied  by  the  perioheral  device  which  generated 
the  interrupt,  and  used  as  a  memory  pointer  to  the  start  address  of  the 
interrupt-handling  routine.  The  addresssmg  mechanism  provided  by 
the  Z80  in  mode  2  is  indirect,  rather  than  direct.  Each  peripheral  sup- 
plies a  seven-bit  branching  address  which  is  appended  to  the  8-bit  ad- 
dress contained  in  the  special  1  register  in  the  Z80.  The  right-most  bit  of 
the  final  16-bit  address  bit  0  is  set  to  "0".  This  resulting  address  points 
to  an  entry  m  a  table  anywhere  in  the  memory.  This  table  may  contain 
up  to  128  double-word  entries.  Each  of  these  double  words  is  the  ad- 
dress of  the  interrupt  handier  for  the  corresponding  device.  This  is  il- 
lustrated in  Figures  6.29  and  6.30. 


DEVICE 


— -INT 


7  eiT  VECTOR 


 i 


START 
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DEViCE 
HANDtER 


2X  VECTOR 


MEMORY 

Fig.  6.29:  Mode  2  Interrupi 

The  interrupt  table  may  have  up  to  128  double-word  entries. 

In  this  mode,  the  280  also  automatically  pushes  the  contents  of  the 
program  counter  into  the  stack.  This  is  obviously  necessary,  since  PC 
will  be  reloaded  with  the  contents  of  the  interrupt  table  entry  corre- 
sponding to  the  vector  provided  by  the  device. 

Interrupt  Overhead 

For  a  graphic  comparison  of  the  polling  process  vs.  the  interrupt 
process,  refer  to  Figure  6.18,  where  the  polling  process  is  illustrated  on 
the  top,  and  the  interrupt  process  underneath.  It  can  be  seen  that  in  the 
polling  technique  the  program  wastes  a  lot  of  time  waiting. 


504 


INPUT/OUTPUT  TECHNIQUES 


0152 


05 


PC 



01 

52 

5P 

so 

00 

VECTOR 
TABLE 


BEFORE 


-0500 


050-^ 


DEVICE  n 

 *~ 

CONTROLLER 

04H 


1000 


PC 



20 

04 

SP 

09 

98 

2004 


AFTER 


MEMORY 


Fig.  6.30:  Mode  2  - A  Practicai  Example 

Using  interrupts,  the  program  is  interrupted,  the  interrupt  is  serviced, 
then  the  program  resumes.  However,  the  obvious  disadvantage  of  an 
interrupt  is  to  introduce  several  additional  instructions  at  the  beginning 
and  at  the  end,  resulting  in  a  delay  before  the  first  instruction  of  the  de- 
vice handler  can  be  executed.  This  is  additional  overhead. 

Exercise  6.28:Using  the  tables  indicating  the  number  of  cycles  per  in- 
struction, in  Chapter  4,  compute  how  much  time  will  be  lost  to  save  and 
then  restore  registers  A,  B,  D,  H. 

Having  clarified  the  operation  of  the  interrupt  lines,  let  us  now  con- 
sider two  important  remaining  problems: 


I — How  do  we  resolve  the  problem  of  multiple  devices  triggering  an 
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interrupt  at  the  same  time? 

2 — How  do  we  resolve  the  problem  of  an  mterrupt  occurrmg  while 
another  interrupt  is  being  serviced? 

Multiple  Devices  Connected  to  a  Single  Interrupt  Line 

Whenever  an  mterrupt  occurs,  the  processor  branches  to  a  specified 
address.  Before  it  can  do  any  effective  processing,  the  interrupt  han- 
dling routine  must  determme  which  device  triggered  the  interrupt.  Two 
methods  are  available  to  identify  the  device,  as  usual:  a  software 
method  and  a  hardware  method. 

In  the  software  method,  polling  is  used:  the  microprocessor  interro- 
gates each  of  the  devices  m  turn  and  asks  them,  "Did  you  trigger  the  in- 
terrupt?" If  the  answer  is  negative,  it  interrogates  the  next  one.  This 
process  is  illustrated  m  Figure  6.31.  A  sample  program  is; 

POLINT     !N        A,  (STATUSl)  READ  STATUS 

BIT      7.  A  DID  DEVICE  REQUEST  INT? 

JP        NZ,  ONE         HANDLE  IT  IF  SO 

IN        A,  (STATUS2) 

BIT      7,  A 

JF        NZ,  TWO 

etc.  — 

The  hardward  method  provides  the  address  of  the  interrupting  device 
simultaneously  with  the  interrupt  request. 
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Fig.  6.31:  Polled  vs.  Vectored  Interrupt 
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To  be  more  precise,  when  operating  in  mode  0,  the  peripheral  device 
controller  will  supply  a  one-byte  RST  or  a  three-byte  CALL  on  the  data 
bus  in  response  to  the  interrupt  acknowledge,  thus  automating  the  in- 
terrupt vectoring,  and  minimizing  the  overhead. 

Note  that  a  subroutine  call  instruction  is  required  as  the  Z80  does  not 
save  the  PC  when  operating  in  mode  0. 

In  most  cases,  the  speed  of  reaction  to  an  interrupt  is  not  crucial,  and 
a  polling  approach  is  used.  If  response  time  is  a  primary  consideration, 
a  hardware  approach  must  be  used. 


Simultaneous  interrupts 

The  next  problem  which  may  occur  is  that  a  new  interrupt  can  be  trig- 
gered during  the  execution  of  an  mterrupt-handling  routine.  Let  us 
examine  what  happens  and  how  the  stack  is  used  to  solve  the  problem. 
We  have  indicated  in  Chapter  2  that  this  was  another  essential  role  of 
the  stack,  and  the  time  has  come  now  to  demonstrate  its  use.  We  will 
refer  to  Figure  6.33  to  illustrate  multiple  mterrupts.  Time  elapses  from 
left  to  right  in  the  illustration.  The  contents  of  the  stack  are  shown  at 
the  bottom  of  the  illustration.  Looking  at  the  left,  at  time  TO,  program 
P  is  in  execution.  Moving  to  the  right,  at  time  Tl,  interrupt  11  occurs. 
We  will  assume  that  the  interrupt  mask  was  enabled,  authorizing  II. 
Program  P  will  be  suspended.  This  is  shown  at  the  bottom  of  the  illus- 
tration. The  slack  will  contain  the  program  counter  and  the  status  reg- 
ister of  program  P,  at  least,  plus  any  optional  registers  that  might  be 
saved  by  the  interrupt  handler  or  II  itself. 
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Fig.  6.32;  Several  Devices  May  Use  the  Same  Inferrupl  Line 

At  time  T 1 ,  interrupt  1 1  starts  executing  until  time  T2.  At  time  T2,  in- 
terrupt 12  occurs.  We  will  assume  that  interrupt  12  has  a  higher  priority 
than  interrupt  II.  If  it  had  a  lower  priority,  il  would  be  ignored  until  II 
had  been  completed.  At  time  T2,  the  registers  for  II  are  stacked,  and 
this  appears  at  the  bottom  of  the  illustration.  Again,  the  contents  of  the 
program  counter  and  AF  are  pushed  into  the  slack.  In  addition,  the 
routine  for  12  might  decide  to  save  an  additional  few  registers.  12  will 
now  execute  to  completion  at  time  T3. 
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When  12  terminates  (with  an  RETI),  the  contents  of  the  stack  are 
automatically  popped  back  into  the  Z80,  and  this  is  illustrated  at  the 
bottom  of  Figure  6.33.  Thus,  automatically  II  resumes  execution.  Un- 
fortunately, at  time  T4,  an  interrupt  13  of  higher  priority  occurs  again. 
We  can  see  at  the  bottom  of  the  illustration  that  again  the  registers  for 
II  are  pushed  into  the  stack.  Interrupt  13  executes  from  T4  to  T5  and 

TIME  r=         T,  T,  t,  t,  T,  T. 

PROGRAM  P  '  I 

INTERRUP!  I,  |P 

INTERRUPT  I,  t 

INTERRUPT  1,  ' 
t 

I 
I 
I 
I 

STACK  rp" 

Fig.  6.33:  Stack  Contents  During  Multiple  Interrupts 

terminates  at  T5.  At  that  time,  the  contents  of  the  stack  are  popped  into 
Z80,  and  interrupt  II  resumes  execution.  This  time  it  runs  to  comple- 
tion and  terminates  at  T6.  At  T6,  the  remaining  registers  that  have  been 
saved  in  the  stack  are  popped  into  Z80,  and  progam  P  may  resume  ex- 
ecution. The  reader  will  verify  that  the  stack  is  empty  at  this  point.  In 
fact,  the  number  of  dashed  lines  indicating  program  suspension  in- 
dicates at  the  same  time  how  many  levels  there  are  in  the  stack. 

Exercise  6.29:  Assume  thai  she  area  available  to  the  slack  is  limited  to 
300  locations  in  a  specific  program.  Assume  that  all  the  registers  must 
always  be  saved  and  that  the  programmer  allows  inlerrupls  to  be  nest- 
ed.  I.e.,  lo  inlerrupi  each  other.  Which  is  the  maximum  number  of 
simultaneous  interrupts  that  can  be  handled?  Will  any  other  factor  con- 
tribute to  still  reduce  further  the  maximum  number  of  simidtaneoiis  in- 
terrupts? 

It  must  be  stressed,  however,  that,  sn  practice,  microprocessor  sys- 
tems are  normally  connected  to  a  small  number  of  devices  using  inter- 
rupts. It  is,  therefore,  unlikely  that  a  high  number  of  simultaneous  in- 
terrupts will  occur  in  such  a  system. 

We  have  now  solved  all  the  problems  usually  associated  with  inter- 
rupts. Their  use  is,  in  fact,  simple  and  they  should  be  employed  to  ad- 
vantage even  by  the  novice  programmer. 
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SUMMARY 

In  this  chapter  we  have  presented  the  range  of  techniques  used  to 
communicate  with  the  outside  world.  From  elementary  input/output 
routines  to  more  complex  programs  for  communication  with  actual 
peripherals,  we  have  learned  to  develop  all  the  usual  programs  and  have 
even  examined  the  efficiency  of  benchmark  programs  in  the  case  of  a 
parallel  transfer  and  a  parallel-Lo-serial  conversion.  Finally,  we  have 
learned  to  schedule  the  operation  of  multiple  peripherals  by  using  poll- 
ing and  interrupts.  Naturally,  many  other  exotic  input/output  devices 
might  be  connected  to  a  system.  With  the  array  of  techniques  which 
have  been  presented  so  far,  and  with  an  understanding  of  the  peripher- 
als involved,  it  should  be  possible  to  solve  most  common  problems. 

In  the  next  chapter,  we  will  examine  the  actual  characteristics  of  the 
input/output  interface  chips  usually  connected  to  a  Z80.  Then,  we  will 
consider  the  basic  data  structures  that  the  programmer  may  use. 

Exercise  6.30:  Compute  the  overhead  when  operating  in  mode  0,  as- 
suming that  all  registers  are  saved,  and  that  an  RST  is  received  in  re- 
sponse to  the  tnterrupl  acknowledge.  The  overhead  is  defined  as  the 
total  delay  incurred,  exclusive  of  the  instructions  required  to  implement 
the  interrupt  processing  proper. 

E.Kercise  6.31:  A  7-segment  LED  display  can  also  display  digits  other 
than  the  hex  alphabet.  Compute  the  codes  for:  H,  L  J.  L.  O.  P.  S.  U, 
Y,  g,  h,  I,  J,  /,     o.  p,  r.  t,  u,  y. 

E.xerclse  6,32:  The  flowchart  for  interrupt  management  appears  in  Fig- 
ure 6.34  Answer  the  following  questions: 

a — What  is  done  by  hardware,  what  is  done  by  software? 

b — Wha!  is  the  use  of  the  mask? 

c — How  many  registers  should  be  preserved? 

d — How  IS  the  interrupting  device  identified? 

e — What  does  the  RETI  instruction  do?  How  does  it  differ  from  a 
subroutine  return? 

f — Suggest  a  way  to  handle  a  stack  overflow  situation. 

g—What  IS  the  overhead  ("lost  time")  introduced  by  the  interrupt 
mechanism? 


509 


PROGRAMMING  THE  Z80 


EXECUrE 
1NS1  RUCTION 


INtERRUft 
^REQUESr^ 


NE)(I  INSTRUCTION 


MASX 
ON 


SET  JAASK 

\ 

■ 

PRESERVE  SEGISIERS 

JOENrfFY  DEVICE 


EXECUTE  ROUTING 


RESTORE  RSGISTESS 
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INTRODUCTION 

We  have  learned  how  to  program  the  Z80  microprocessor  in  most 
usual  situations.  However,  we  should  make  a  special  mention  of  the 
input/output  chips  normally  connected  to  the  microprocessor.  Be- 
cause of  the  progress  in  LSI  integration,  new  chips  have  been  intro- 
duced which  did  not  exist  before.  As  a  result,  programming  a  system 
requires,  naturally,  first  to  program  a  microprocessor  itself,  and  then 
to  program  the  input/output  chips.  In  fact,  it  is  often  more  difficult 
to  remember  how  to  program  the  various  control  options  of  an  input/ 
output  chip  than  to  program  the  microprocessor  itself!  This  is  not  be- 
cause the  programming  in  itself  is  more  difficult,  but  because  each  of 
these  devices  has  its  own  idiosyncrasies.  We  are  going  to  examine  here 
first  the  most  general  input/output  device,  the  programmable  input/ 
output  chip  (in  short  a  "PIO").  then  some  Zilog  I/O  devices. 

The  "Standard  PIG" 

There  is  no  "standard  PIO".  However,  each  PlOdevice  is  essentially 
analogous  in  function  to  all  similar  PIO's  produced  by  other 
manufacturers  for  the  same  purpose.  The  purpose  of  a  PIO  is  to 
provide  a  multiport  connection  for  input/output  devices.  (A  "port"  is 
simply  a  set  of  8  input/output  lines.)  Each  PIO  provides  at  least 
two  sets  of  8-bit  lines  for  I/O  devices.  Each  I/O  device  needs  a  data 
buffer  in  order  to  stabilize  the  contents  of  the  data  bus  on  output  at 
least.  Our  PIO  will,  therefore,  be  equipped  at  a  minimum  with  a 
buffer  for  each  port. 

In  addition,  we  have  established  that  the  microcomputer  will  use 
a  handshaking  procedure,  or  else  interrupts  to  communicate  with  the 
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I/O  device.  The  PIO  will  also  use  a  similar  procedure  to  communicate 
With  the  peripheral.  Each  PIO  must,  therefore,  be  equipped  with  at 
least  two  control  lines  per  port  to  implement  the  handshaking 
function. 

The  microprocessor  will  also  need  to  be  able  to  read  the  status  of 
each  port.  Each  port  must  be  equipped  with  one  or  more  status  bits. 
Finally,  a  number  of  options  will  exist  within  each  PIO  to  configure  its 
resources.  The  programmer  must  be  able  to  access  a  special  register 
withm  the  PIO  to  specify  the  programming  options.  This  is  the 
control-register.  In  some  cases  the  status  information  is  part  of  the 
control  register. 
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Fig.  7.1:  Typical  PIO 

One  essential  faculty  of  the  PIO  is  the  fact  that  each  Hne  may  be 
configured  as  either  an  input  or  an  output  line.  The  diagram  of 
a  PIO  appears  in  illustration  7. 1 .  The  programmer  may  specify 
whether  any  line  will  be  input  or  output.  In  order  to  program  the 
direction  of  the  lines,  a  data-direction  register  is  provided  for  each 
port.  On  many  PIO's,  "0"  in  a  bit  position  of  the  data-direction 
register  specifies  an  input.  A  "1"  specifies  an  output,  Zilog  uses  the 
reverse  convention. 

It  may  be  surprising  to  see  that  a  "0"  is  used  for  input  and  a  "1" 
for  output  when  really  "0"  should  correspond  to  output  and  "1"  to 
input.  This  Is  quite  deliberate:  whenever  power  is  applied  to  the 
system,  it  is  of  great  importance  that  all  the  I/O  lines  be  configured  as 
input.  Otherwise,  if  the  microcomputer  is  connected  to  some 
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dangerous  peripheral,  it  might  activate  it  by  accident.  When  a  reset  is 
applied,  ail  registers  are  normally  zeroed  and  that  will  result  in  con- 
figuring all  input  lines  of  the  PIO  as  inputs.  The  connection  to  the 
microprocessor  appears  on  the  left  of  the  illustration.  The  PIO 
naturally  connects  to  the  8-bit  data  bus,  the  microprocessor  address 
bus,  and  the  microprocessor  control-bus.  The  programmer  will  simply 
specify  the  address  of  any  register  that  it  wishes  to  access  within  the 
PIO. 

The  Internal  Control  Register 

The  Control  Register  of  the  PIO  provides  a  number  of  options  for 
generating  or  sensing  interrupts,  or  for  implementing  automatic  hand- 
shake functions.  The  complete  description  of  the  facilities  provided  is 
not  necessary  here.  Simply,  the  user  of  any  practical  system  which  uses 
a  PIO  will  have  to  refer  to  the  data-sheet  showing  the  effect  of  setting 
the  various  bits  of  the  control  register.  Whenever  the  system  is 
initialized,  the  programmer  will  have  to  load  the  control  register  of  the 
PIO  with  the  correct  contents  for  the  expected  application. 
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Fig.  7.5:  Using  a  PIO  Read  INPUT 
Programrning  a  PIO 

A  typical  sequence,  when  usmg  a  PIO  channel,  is  the  following  (as- 
suming an  input): 


Load  the  control  register 

This  is  accomplished  by  a  programmed  transfer  between  a  Z80  re- 
gister (usually  the  accumulator)  and  the  PIO  control  register.  This  sets 
the  options  and  operating  mode  of  the  PIO  (see  Figure  7.2).  It  is  nor- 
mally done  only  once  at  the  beginning  of  a  program. 

Load  the  direction  register 

This  specifies  the  direction  in  which  the  I/O  lines  will  be  used.  (See 
Figure  7.3.) 

Read  the  status 

The  status  register  indicates  whether  a  valid  byte  is  available  on  in- 
put. (See  Figure  7.4X 

Read  the  port 
The  byte  is  read  into  the  Z80.  (See  Figure  7.5). 
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Fig.  7.6:  Z80  PIO  pinout 


TheZiiogZSOPIO 

The  Z80  PIO  is  a  two-port  PIO  whose  architecture  is  essentially 
compatible  with  the  standard  model  we  have  described.  The  actual 
pinout  is  shown  in  Figure  7. 6,  and  a  block  diagram  is  shown  in  Figure 
7.7. 

Each  PIO  port  has  six  registers:  an  8-bit  input  register,  an  8- bit  out- 
put register,  a  2-bit  mode-controi  register,  an  8-bit  mask  register,  an 
8-bit  input/output  select  (direction  register),  and  a  2-bit  mask-control 
register.  The  last  three  registers  are  used  only  when  the  port  is  program- 
med to  operate  in  the  bit  mode. 

Each  port  may  operate  in  one  of  four  modes,  as  selected  by  the  con- 
tents of  the  mode-control  registers  {2  bits).  They  are:  byte  output,  byte 
input,  byte  bidirectional  bus,  and  bit  mode. 

The  two  bits  of  the  mask  control  register  are  loaded  by  the  program- 
mer, and  specify  the  high  or  low  state  of  a  peripheral  device  which  Is  to 
be  monitored,  and  conditions  for  which  an  interrupt  can  be  generated, 
generated. 

The  8-bit  input/output  select  register  allows  any  pin  to  be  either  an 
input  or  an  output  when  operating  in  the  bit  mode. 
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Programming  the  Ziiog  PIO 

A  typical  sequence  for  using  a  PIO,  say  in  bit  mode,  would  be  the 
following: 

Load  the  mode  control  register  to  specify  the  bit  mode. 

Load  the  input/output  select  register  of  port  A  to  specify  that 
lines  0-5  are  inputs  and  lines  6  and  7  are  outputs. 

Then  a  word  would  be  read  by  reading  the  contents  of  the  input 
buffer. 

Additionally,  the  mask  register  could  be  used  to  specify  the  status 
conditions. 

For  a  detailed  description  of  the  operation  of  the  PIO,  the  reader  is 
referred  to  the  companion  volume  in  this  series,  the  Z80  Applications 
Book. 


The  Z80  SIO 

The  SIO  (Serial  Input/Output)  is  a  dual-channel  peripheral  chip  de- 
signed to  facilitate  asynchronous  communications  in  serial  form.  It  in- 
cludes a  UART,  i.e.,  a  universal  asynchronous  receiver-transmitter. 
Its  essential  function  is  serial- to-parallel  and  parallel-to-serial  conver- 
sion. However,  this  chip  is  equipped  with  sophisticated  capabilities, 
like  automatic  handling  of  complex  byte-oriented  protocols,  such  as 
IBM  bisync  as  well  as  HDLC  and  SDLC,  two  bit-oriented  protocols. 

Additionally,  it  can  operate  in  synchronous  mode  like  a  USRT,  and 
generate  and  check  CRC  codes.  It  offers  a  choice  of  polling,  interrupt, 
and  block- transfer  modes.  The  complete  description  of  this  device  is 
beyond  the  scope  of  this  introductory  book  and  appears  in  the  Z80  Ap- 
plications Book. 


Other  I/O  Chips 

Because  the  Z80  is  commonly  used  as  a  replacement  for  the  8080,  it 
has  been  designed  so  that  it  can  be  associated  with  almost  any  of  the 
usual  8080  input/output  chips,  as  well  as  the  specific  I/O  chips  manu- 
factured by  Zilog.  All  the  8080  input/output  chips  may  be  considered 
for  use  in  a  Z80  system. 
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SUMMARY 

In  order  to  make  eflective  use  of  mpui/ouipui  components  it  i.s 
necessary  to  understand  in  detail  the  function  of  every  bit,  or  group  of  bits, 
wiihm  the  various  control  registers.  These  complex  new  chips  automate  a 
number  of  procedures  that  had  lo  be  carried  out  by  software  or  special 
logic  before.  In  particular,  a  gooddealof  the  handshaking  procedures  are 
automated  within  components  such  as  an  SIO.  Also,  interrupt  handling 
and  detection  may  be  internal.  With  the  mformaiion  that  has  been  pre- 
sented m  the  preceding  chapter,  the  reader  should  be  able  to  understand 
what  the  functions  of  the  basic  signals  and  registers  are.  Naturally,  still 
newer  components  are  going  to  be  introduced  which  will  offer  a  hardware 
implementation  of  still  more  complex  algorithms. 
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INTRODUCTION 

This  chapter  is  designed  to  test  your  new  programming  skills  by  pre- 
senting a  collection  of  utility  programs.  These  programs  or  "routines" 
are  frequently  encountered  in  applications,  and  are  generally  called 
"utility  routines."  They  will  require  a  synthesis  of  the  knowledge  and 
techniques  presented  so  far. 

We  are  going  to  fetch  characters  from  an  I/O  device  and  process 
them  in  various  ways.  But  first,  let  us  clear  an  area  of  the  memory  (this 
may  not  be  necessary — each  of  these  programs  is  only  presented  as  a 
programming  example). 

CLEARING  A  SECTION  OF  MEMORY 

We  want  to  clear  (zero)  the  contents  of  the  memory  from  address 
BASE  to  address  BASE  ±  LENGTH,  where  LENGTH  is  less  than  256. 


The  program  is: 


ZEROM 

LD 

B.  LENGTH 

LOAD  B  WITH  LENGTH 

LD 

A,0 

CLEAR  A 

LD 

HL,  BASE 

POINT  TO  BASE 

CLEAR 

LD 

(HL),  A 

CLEAR  A  LOCATION 

INC 

HL 

POINT  TO  NEXT 

DEC 

B 

DECREMENT  COUNTER 

JR 

NZ,  CLEAR 

END  OF  SECTION? 

RET 

In  the  above  program,  the  length  of  the  section  of  memory  is  as- 
sumed 10  be  equal  to  LENGTH.  The  register  pair  HL  is  used  as  a  point- 
er to  the  current  word  which  will  be  cleared.  Register  B  is  used,  as 
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usual,  as  a  counter. 

The  accumulator  A  is  ioaded  only  once  with  the  value  0  (ail  zeros), 
then  copied  into  the  successive  memory  locations. 

In  a  memory  test  program,  for  example,  this  utility  routine  could  be 
used  Eo  zero  the  conienis  of  a  block.  Then  the  memory  test  program 
would  usually  verify  that  us  contents  remamed  0. 

The  above  was  a  straightforward  implementation  of  a  clearing  rou- 
tine. Let  us  improve  on  it. 

The  improved  program  appears  below. 


The  two  improvements  were  obiamed  by  eliminating  the  LD  A,  0  in- 
struction and  loading  a  "zero"  directly  into  the  location  pointed  to  by  H 
and  L,  and  also  by  using  the  special  Z80  instruction  DJNZ. 

This  improvement  example  should  demonstrate  that  every  lime  a 
program  is  wniten,  even  ihough  it  may  be  correct,  it  can  usually  be  im- 
proved by  examining  it  carefully.  Familiarity  with  the  complete  instruc- 
tion set  is  essential  for  bringing  about  such  improvements.  These  im- 
provements are  not  just  cosmetic.  They  improve  the  execution  time  of 
the  program,  require  fewer  instructions  and  therefore  less  memory 
space,  and  also  generally  improve  the  readability  of  the  program  and, 
therefore,  its  chances  of  being  correct. 

Exercise  8.1:  Write  a  memory  test  program  which  zeroes  a  25 6- word 
block,  then  verifies  that  each  location  is  0.  Then,  it  will  write  all  I  'sand 
verify  the  contents  of  the  block.  Then  it  will  write  OlOlOlOl  and  verify 
the  contents.  Finally,  it  will  write  1010 1010,  and  verify  the  contents. 

txerclse  8.2:  Modify  the  above  program  so  that  it  will  fill  the  memory 
section  with  alternating  O's  and  I's  {all  O's.  then  all  I's). 

Let  us  now  poll  our  I/O  devices  to  find  which  one  needs  service. 

POLLING  I/O  DEVICES 

We  will  assume  that  those  I/O  devices  are  connected  to  our  sys- 
tem. Their  status  registers  are  located  at  addresses  STATUS  1, 
STATUS2,  STATUS3.  The  program  is: 


ZEROM 


LD        B,  LENGTH 
LD      ,.HL,  BASE 
LD       (HL),  0 
INC  HL 
DJNZ  LOOP 
RET 


LOOP 
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IN 

A,  {STATUS!) 

READ  lO  STATUS  1 

BIT 

7,  A 

TEST  "READY"  BIT  (BIT  7) 

JP 

NZ,  FOUND  1 

JUMP  TO  HANDLER  i 

IN 

A,  (STATUS2) 

SAME  FOR  DEVICE  2 

BIT 

7,  A 

JP 

NZ,  FOUND2 

IN 

A,  (STATUS3) 

SAME  FOR  DEVICE  3 

BIT 

7,  A 

JP 

NZ,  FOUND3 

(failure  exit) 

The  MASK  will  contain,  for  example,  "10000000"  if  we  test  bit  posi- 
tion 7.  As  a  result  of  the  BIT  instruction,  the  Z  bit  of  the  status  flags 
will  be  set  to  1  if  "MASK  AND  STATUS"  is  zero,  i.e.,  if  the  cor- 
responding bit  of  STATUS  matches  the  one  in  MASK,  The  JP  NZ  in- 
struction Gump  if  non-equal  to  zero)  will  then  result  in  a  branch  to  the 
appropriate  FOUND  routine. 

GETTING  CHARACTERS  IN 

Assume  we  have  just  found  that  a  character  is  ready  at  the  keyboard. 
Let  us  accumulate  characters  in  a  memory  area  called  BUFFER  until  we 
encounter  a  special  character  called  SPC,  whose  code  has  been  previ- 
ously defined. 

The  subroutine  GETCHAR  will  fetch  one  character  from  the  key- 
board (see  Chapter  6  for  more  details)  and  leave  it  m  the  accumulator. 
We  assume  that  256  characters  maximum  will  be  fetched  before  an  SPC 
character  is  found. 


STRING 

LD 

HL,  BUFFER 

POINT  TO  BUFFER 

NEXT 

CALL 

GETCHAR 

GET  A  CHARACTER 

CP 

SPC 

CHECK  FOR  SPECIAL  CHAR 

JR 

2,  OUT 

FOUND  IT? 

(HL),  A 

STORE  CHAR  IN  BUFFER 

INC 

HL 

NEXT  BUFFER  LOCATION 

JR 

NEXT 

GET  NEXT  CHAR 

OUT 

RET 

Exercise  8.3:  Let  us  improve  ihis  basic  routine: 

a — Echo  the  character  back  to  the  device  (for  a  Teletype,  for  example), 

b — Check  that  the  input  sirmg  is  no  longer  than  256  characters. 

We  now  have  a  string  of  characters  m  a  memory  buffer.  Let  us  proc- 
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ess  them  in  various  ways. 


TESTING  A  CHARACTER 

Let  us  determine  if  the  character  at  memory  location  LOG  is  equal  to 
0,  1,  or  2: 


LD 

A,  {LOO 

GET  CHARACTER 

CP 

00 

IS  IT  A  ZERO? 

JP 

Z,  ZERO 

JUMP  TO  ROUTINE 

CP 

01 

A  ONE? 

JP 

Z,  ONE 

CP 

02 

A  TWO? 

JP 

Z,  TWO 

JP 

NOTFND 

FAILURE 

We  sjmply  read  the  character,  then  use  the  CP  instruction  to  check  its 
value. 

Lei  us  run  a  different  lest  now. 

BRACKET  TESTING 

Let  us  determine  if  the  ASCII  character  at  memory  location  LOC  is  a 
digit  between  0  and  9; 


BRACK  LD 

A,  (LOC) 

GET  CHARACTER 

AND 

7FH 

MASK  OUT  PARITY  BIT 

CP 

30H 

ASCII  0 

JR 

C,  OUT 

CHAR  TOO  LOW? 

CP 

39H 

ASCII  9 

JR 

NC,  OUT 

CHAR  TOO  HIGH? 

CP 

A 

FORCE  ZERO  FLAG 

OUT  RET 

EXIT 

ASCII  "0"  is  represented  in  hexadecimal  fay  "30"  or  by  "BO", 
depending  upon  whether  the  parity  bit  is  used  or  not.  Similarly,  ASCII 
"9"  is  represented  in  hexadecimal  by  "39"  or  by  "B9". 

The  purpose  of  the  second  msiruciion  of  the  program  is  to  delete  bit 
7,  the  parity  bit,  in  case  it  was  used,  so  that  the  program  ts  applicable  to 
both  cases.  The  value  of  the  characier  is  then  compared  to  the  ASCII 
values  for  "0"  and  "9".  When  using  a  comparison  instruction,  the  Z 
flag  is  set  if  the  comparison  succeeds.  The  carry  bit  is  set  in  the  case  of 
borrow,  and  reset  otherwise.  In  other  words,  when  using  the  CP  in- 
struction, the  carry  bit  will  be  set  if  the  value  of  the  literal  that  appears 
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in  the  instruction  is  greater  than  the  value  contained  in  the  accumu- 
lator. It  will  be  reset  ("0")  if  less  than  or  equal. 

The  last  instruction.  CP  A,  forces  a  "1"  into  the  Z  flag.  The  Z  flag  is 
used  to  indicate  to  the  calling  routine  that  the  character  in  CHAR  was 
indeed  in  the  interval  (0,  9).  Other  conventions  can  be  used,  such  as 
loading  a  digit  in  the  accumulator  in  order  to  indicate  the  result  of  the 
test. 

Exercise  8.4:  Is  (he  following  program  equivalent  to  the  one  above?: 

LD       A,  (CHAR) 

SUB  30H 

JP        M,  OUT 

SUB  iO 

JP        P,  OUT 

ADD  10 

Exercise  8. 5:  Determine  if  an  A  SCII  character  contamed  m  the  accumu- 
lator is  a  letter  of  the  alphabet. 

When  using  an  ASCII  table,  you  will  notice  that  parity  is  often  used. 
For  example,  the  ASCII  for  "0"  is  "01 10000",  a  7-bit  code.  However, 
if  we  use  odd  parity,  for  example,  we  guarantee  that  the  total  number 
of  ones  inawordis  odd;  then  the  code  becomes:  "10110000".  An  extra 
"  1 "  is  added  to  the  left.  This  is  "  BO  "  in  hexadecimal.  Let  us  therefore 
develop  a  program  to  generate  parity. 

PARITY  GENERATION 

This  program  will  generate  an  even  parity  with  bit  position  7: 


PARITY  LD 

A,  (CHAR) 

GET  CHARACTER 

AND 

7FH 

CLEAR  PARITY  BIT 

JP 

PE,  OUT 

CHECK  IF  PARITY 

ALREADY  EVEN 

OR 

80  H 

SET  PARITY  BIT 

OUT  LD 

(LOC),  A 

STORE  RESULT 

The  program  uses  the  internal  parity  detection  circuit  available  in  the 
Z80. 

The  third  instruction:  JP  PE,  OUT  checks  whether  parity  of  the 
word  in  the  accumulator  is  already  even.  This  instruction  will  succeed  if 
the  parity  is  even,  "PE".  and  will  exit. 

If  the  parity  is  not  even.  i.e..  if  the  jump  instruction  failed,  then  the 
parity  is  odd,  and  a  "1"  must  be  written  in  bit  position  7.  This  is  the 
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purpose  of  the  fourth  instruction: 
OR  80H 

Finally,  the  resulting  value  is  saved  in  memory  location  LOG. 

Exercise  8.6:  The  above  problem  was  too  simple  to  solve,  using  the  in- 
ternal parity  detection  circuitry.  As  an  exercise,  you  are  requested  to 
solve  the  same  problem  without  using  this  circuitry.  Shift  the  contents 
of  the  accumulator,  and  count  the  number  of  I's  in  order  to  determine 
which  bit  should  be  written  into  the  parity  position. 

Exercise  S.7:  Using  the  above  program  as  an  example,  verify  the  parity 
of  a  word.  You  must  compute  the  correct  parity,  then  compare  ii  to  the 
one  expected. 

CODE  CONVERSION:  ASCI!  TO  BCD 

Converting  ASCII  to  BCD  is  very  simple.  We  will  observe  that  the 
hexadecimal  representation  of  ASCII  characters  0  to  9  is  30  to  39  or  BO 
to  B9,  depending  on  parity.  The  BCD  representation  is  simply  obtained 
by  dropping  the  "3"  or  the  "B",  i.e.,  masking  off  the  left  nibble  (4 
bits): 

ASCBCD  CALL  BRACK  CHECK  THAT  CHAR  IS  0  TO  9 

JP        NZ,  ILLEGAL    EXIT  IF  ILLEGAL  CHAR 
AND    OFH  MASK  HIGH  NIBBLE 

LD       (BCDCHAR),  A  STORE  RESULT 

E.xercise  8,8:  Write  a  program  to  convert  BCD  to  ASCII. 

E.xercise  8.9:  Write  a  program  to  convert  BCD  to  binary  (more  diffi- 
cult). 

Hint:N,N,N,No!nBCDis({(N,  x  10)  +  N,)  x  !0  +  N,)  x  10  +  Norn 
binary. 

To  multiply  by  10,  use  a  left  shift  ( =  x2),  another  left  shift  { =  x4}, 
an  ADC  (  =  x5),  another  left  shift      x  10). 

In  full  BCD  notation,  the  first  word  may  contain  the  count  of  BCD 
digits,  the  next  nibble  contain  the  sign,  and  every  successive  nibble  con- 
tain a  BCD  digit  (we  assume  no  decimal  point).  The  last  nibble  of  the 
block  may  be  unused. 

CONVERT  HEX  TO  ASCII 

"a" contains  one  hexadecimal  digit.  We  simply  need  to  add  a  "3"  (or  a 
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"B")  into  the  lefl  nibble: 

AND  OFH  ZERO  LEFT  NIBBLE  (optional) 

ADD  A,  30H  ASCII 

CP  A,  3AH  CORRECTION  NECESSARY? 

JP  M,  OUT 

ADD  A,  7  CORRECTION  FOR  A  TO  F 

Exercise  8. 10:  Convert  HEX  to  ASCII,  assuming  a  packed  forma!  (two 
hex  digits  III  A). 


FINDING  THE  LARGEST  ELEMENT  OF  A  TABLE 

The  beginning  address  of  the  table  is  contained  at  memory  address 
BASE.  The  first  entry  of  the  table  is  the  number  of  bytes  it  contains. 
This  program  wiil  search  for  the  largest  element  of  the  table.  Its  value 
will  be  left  in  A,  and  its  position  will  be  stored  in  memory  location  IN- 
DEX. 

This  program  uses  registers  A,  F,  B,  H  and  L,  and  will  use  indirect 
addressing,  so  that  it  can  search  a  table  anywhere  in  the  memory  (see 
Figure  8.1). 


MAX 

LD 

HL,  BASE 

TABLE  ADDRESS 

LD 

B,  (HL) 

NBR  OF  BYTES  IN  TABLE 

LD 

A,  0 

CLEAR  MAXIMUM  VALUE 

INC 

HL 

INITIALIZE  INDEX 

LD 

(INDEX),  HL 

NEXT  ENTRY 

LOOP 

CP 

(HL) 

COMPARE  ENTRY 

JR 

NC,  NOSWITCH 

JUMP  IF  LESS  THAN  MAX 

LD 

A,  (HL) 

LOAD  NEW  MAX  VALUE 

LD 

(INDEX),  HL 

LOAD  NEW  MAX  VALUE 

NOSWITCH 

INC 

HL 

POINT  TO  NEXT  ENTRY 

DEC  B 

DECREMENT  COUNTER 

JR 

NZ,  LOOP 

KEEP  GOING  IF  NOT  ZERO 

RET 

This  program  tests  the  nth  entry  first.  If  it  is  greater  than  0,  the  entry 
goes  in  A,  and  its  location  is  remembered  into  INDEX.  The  (n-I)st  en- 
try is  then  tested,  etc. 

This  program  works  for  positive  integers. 

Exercise  8.1 1:  Modify  the  program  so  that  it  works  also  for  negative 
numbers  m  two's  complement. 

Exercise  8.12:  Will  this  program  also  work  for  ASCII  characters? 
Exercise  8. 13:  Write  a  program  which  will  sort  n  numbers  in  ascending 
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A  I     CURRENT  MAX  ( 


B  [        COUNTER  I 


HL 


V 


INDEX 

POINTER  TO 
"        MAX  ~ 

BASE 

COUNT=N 

ELEMENT  1 

• 
• 
• 

INCREASING 
ADDRESSES 

ELEMENT  N 

Fig.  8. 1:  Largest  Element  in  a  Table 


order. 

Exercise  8, 14:  Write  a  program  which  will  sort  n  names  (3  characters 
each)  m  alphabetical  order. 

SUM  OF  N  ELEMENTS 

This  program  will  compute  the  16-bit  sum  of  N  positive  entries  of  a 
table.  The  starting  address  of  the  table  is  contained  at  memory  address 
BASE.  The  first  entry  of  the  table  contains  the  number  of  elements  N. 
The  16-bit  sum  will  be  left  in  memoy  locations  SUMLO  and  SUMHL  If 
the  sum  should  require  more  than  16  bits,  only  the  iower  16  will  be 
kept.  (The  high  order  bits  are  said  to  be  truncated.) 

This  program  will  modify  registers  A,  F,  B,  H,  L,  IX.  It  assumes  256 
elements  maximum  (see  Figure  8.2). 

SUMN         LD     HL.  BASE       POINT  TO  TABLE  BASE 
LD     B,  (HL)  READ  LENGTH  INTO 

COUNTER 

SUMIG        INC    HL  POINT  TO  FIRST  ENTRY 

LD     IX,  SUMLO     POINT  TO  RESULT,  LOW 
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ADLOOP 


NOCARRY 


LD 

(IX +  0),  0 

CLEAR  RESULT  LOW 

LD 

(1X4-  1),  0 

AND  HIGH 

LD 

A,  (HL) 

GET  TABLE  ENTRY 

ADD 

A,  (IX  4- 0) 

COMPUTE  PARTIAL  SUM 

LD 

(IX +  0),  A 

STORE  IT  AWAY 

JR 

NC,  NOCARRY 

CHECK  FOR  CARRY 

INC 

(IX  + 1) 

ADD  CARRY  TO  HIGH  BYTE 

INC 

HL 

POINT  TO  NEXT  ENTRY 

DEC 

B 

DECREMENT  BYTE  COUNT 

JR 

NZ,  ADLOOP 

KEEP  ADDING  TILL  END 

RET 

COUNT 


HL 


BASE 
 1  


1 


LENGTH  =  N 


ELEMENT 


9 


BASE 


ELEMENT  N 


SUMLO 
SUMH  I 


Fig.  8.2:  Sum  of  N  Elements 

This  program  is  straightforward  and  should  be  self-explanatory. 

Exercise  8.15:  Modify  this  program  to: 
a— compute  a  24-bit  sum 
b— compute  a  32-bit  sum 
c — detect  any  overflow. 

A  CHECKSUM  COMPUTATION 

A  checksum  is  a  digit  or  set  of  digits  computed  from  a  block  of  suc- 
cessive characters.  The  checksum  !s  computed  at  the  time  the  data  is 
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stored  and  pul  at  the  end.  In  order  to  verify  the  integrity  of  the  data,  the 
data  is  read,  then  the  checksum  is  recomputed  and  compared  against 
the  stored  value.  A  discrepancy  indicates  an  error  or  a  failure. 

Several  algorithms  are  used.  Here,  we  will  exciusive-OR  all  bytes  in  a 
table  of  N  elements,  and  leave  the  result  m  the  accumulator.  As  usual, 
the  base  of  the  table  is  stored  at  address  BASE.  The  first  entry  of  the 
table  is  its  number  of  elements  N.  The  program  modifies  A,  F,  B,  H,  L. 
N  must  be  less  than  256 


CHKSUM 


CHLOOP 


LD 

HL,  BASE 

LOAD  ADDRESS  OF  TABLE 

INTO  HL 

LD 

B,  (HL) 

GET  N  =  LENGTH 

XOR 

A 

CLEAR  CHECKSUM 

INC 

HL 

POINT  TO  FIRST  ELEMENT 

XOR 

(HL) 

COMPUTE  CHECKSUM 

INC 

HL 

POINT  TO  NEXT  ELEMENT 

DEC 

B 

DECREMENT  COUNTER 

JR 

NZ,  CHLOOP 

DO  IT  AGAIN  IF  NOT  END 

LD 

(CHECKSUM),A  PRESERVE  CHECKSUM 

RET 

COUNT  THE  ZEROES 


This  program  will  count  the  number  of  zeroes  in  our  usual  table,  and 
leave  it  in  location  TOTAL.  It  modifies  A,  B,  C,  H,  L,  F. 


ZEROS 

LD 

HL,  BASE 

POINT  TO  TABLE 

LD 

B,  (HL) 

READ  LENGTH  INTO  COUNTER 

LD 

C,  0 

ZERO  TOTAL 

INC 

HL 

POINT  TO  FIRST  ENTRY 

ZLOOP 

LD 

A,  (HL) 

GET  ELEMENT 

OR 

0 

SET  ZERO  FLAG 

JR 

NZ,  NOTZ 

IS  IT  A  ZERO? 

INC 

C 

IF  SO,  INCREMENT  ZERO  COUNT 

NOTZ 

INC 

HL 

POINT  TO  NEXT  ENTRY 

DEC 

B 

DECREMENT  LENGTH  COUNTER 

JR 

NZ,  ZLOOP 

LD 

A,C 

LD 

(TOTAL),  A 

SAVE  IT 

Exercise  8.16:  Modify  if  us  program  lo  count 
a — the  number  of  stars  (the  cliaracter  "*") 
b — tlie  number  of  letters  of  the  alpliabet 
c — the  number  of  digits  between  "0"  and  "9" 
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BLOCK  TRANSFER 


Let  us  pick  up  every  third  entry  in  the  source  block  at  address  FROM 
and  store  it  into  a  block  at  address  TO: 


FER3 


LD 

HL,  FROM 

LD 

DE,  TO 

SET  UP  POINTERS 

LD 

BC,  SIZE 

LDI 

AUTOMATED  TRANSFER 

INC 

HL 

INC 

HL 

SKIP  2  ENTRIES 

JP 

PE,  LOOP 

BCD  BLOCK  TRANSFER 


We  will  push  up  BCD  digits  m  the  memory,  i.e,  shift  4-bit  nibbles 
(see  Figure  8  .3).    The  program  appears  below: 


COUNT 


Fig.  8.3:  BCD  Block  Transfer -The  Memory 


DMOV    LD  B,  COUNT 

LD  HL,  BLOCK 

XOR  A  A  =  0 

LOOP  RLD 

DEC  HL  POINT  TO  NEXT  BYTE 

DJNZ  LOOP  DEC  COUNT  LOOP  UNTIL  ZERO 
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The  program  uses  the  RLD  instruction,  which  we  have  not  used  yet. 
RLD  rotates  a  BCD  digit  left  between  A  and  (HL).  (HL)  or  M  designate 
the  contents  of  the  memory  location  pointed  to  by  H  and  L. 

M  LOW  goes  into  M  HIGH 
M  HIGH  goes  into  A  LOW 
A  LOW  goes  into  M  LOW 

Here,  "low"  and  "high"  refer  to  a  4-bit  nibble. 

In  order  to  use  the  powerful  DJNZ  instruction,  register  B  is  used  as 
the  digit  counter.  HL  is  set  to  point  to  the  beginning  of  the  block. 

A  is  used  to  store  the  left  digit  displaced  by  each  rotation  between 
two  successive  accesses  to  the  block. 

By  convention,  "0"  will  be  entered  at  the  bottom  of  the  block. 

COMPARE  TWO  SIGNED  16-BIT  NUMBERS 

IX  points  to  the  first  number  Nl. 
lY  points  to  N2  (see  Figure  8.4). 

The  program  sets  the  carry  bit  if  NI<  N2,  and  the  Z  bit  if  Nl  =  N2, 


COMP  LD 
LD 
AND 
JR 
BIT 
RET 
LD 
CP 
RET 
LD 
CP 
RET 

NEGMl  XOR 

RET 

LD 

CP 

RET 

LD 

CP 

RET 

The  program  first 


GET  SIGN  OF  Nl 

TEST  SIGN,  CLEAR  CY 
Nl  IS  NEG 

N2  IS  NEG 

SIGNS  ARE  BOTH  POS 


B,  (IX +  1) 
A,  B 
80H 

NZ,  NEGMl 
7,  {IY+  !) 
NZ 
A,  B 
(lY-f  1) 
NZ 

A,  (IX) 
(lY) 

(JY  +  1) 
C 

A,  B 

(lY+n 

NZ 

A,  (IX) 
(lY) 


tests  the  signs  of  Nl  and  N2.  If  Nl  is  negative,  a 


SIGN  BIT  INTO  CY 
SIGNS  DIFFERENT 

BOTH  SIGNS  NEG 
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jump  occurs  to  NEGlv!\.  Otherwise,  the  top  of  the  program  is  executed. 


MEMORY 


IX 


lY 


Nl,  LOW 
Nl,  HIGH 


N2,  LOW 
N2,  HIGH 


'  HiGH  ADDRESSES 


Fig.  8.4:  Comparing  Two  Signed  Numbers 

Note  that  the  BIT  instruction  is  used  in  the  5th  line  to  test  directly  the 
sign  bit  of  N2  m  the  memory: 


BIT 


7,  (iY  +  1) 


The  same  could  have  been  done  for  Nl,  except  that  we  will  need  the 
value  of  Nl  shortly.  It  is  therefore  simpler  to  read  Nl  from  memory 
and  preserve  it  into  B; 

COMP      LD       B,  (IX  +  I) 

It  is  necessary  to  preserve  Nl  into  B  because  the  AND  may  destroy  the 
contents  of  A; 

LD       A.  B 
AND  80H 

Note  also  that  a  conditional  return  is  used  (line  6): 
RET  NZ 
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This  IS  a  powerful  feature  of  the  Z80  which  simplifies  programming. 

Note  that  the  comparison  instruction  executes  directly  on  the  con- 
tents of  memory,  in  indexed  mode: 

CP       (lY  +  !) 

When  comparing  the  two  numbers,  the  most  significant  byte  is  com- 
pared first,  the  least  significant  one  second. 

Note  the  extensive  use  of  the  indexing  mechanism  in  this  program, 
which  results  in  efficient  code. 

BUBBLE-SORT 

Bubble-sort  is  a  sorting  technique  used  to  arrange  the  elements  of  a 
table  m  ascending  or  descending  order.  The  bubble-sort  technique  de- 
rives its  name  from  the  fact  that  the  smallest  element  "bubbles  up"  to 
ihe  top  of  the  table.  Every  time  it  "collides"  with  a  "heavier"  element, 
it  jumps  over  it. 

A  practical  example  of  a  bubble-sort  is  shown  on  Figure  8.5  The  list 
to  be  sorted  contains:  {10,  5,  0,  2,  100),  and  must  be  sorted  m  descend- 
ing order  ("0"  on  top).  The  algorithm  is  simple,  and  the  flowchart  is 
shown  on  Figure  8.7 

The  top  two{or  else  bottom  twojelements  are  compared.  If  the  lower 
one  IS  less  ("lighter")  than  the  top  one.  they  are  exchanged.  Otherwise 
not.  For  practical  purposes,  the  exchange,  if  it  occurs,  will  be  remem- 
bered in  a  flag  called  "EXCHANGED".  The  process  is  then  repeated 
on  the  next  pair  of  elements,  etc.,  until  all  elements  have  been  com- 
pared two  by  two. 

This  first  pass  is  illustrated  by  steps  1 ,  2,  3,  4,  5,  6  on  Figure  8.5,  go- 
ing from  the  bottom  up.  (Equivalently  we  could  go  from  the  top  down.) 

If  no  elements  have  been  exchanged,  the  sort  is  complete.  If  an  ex- 
change has  occurred,  we  start  ail  over  again. 

Looking  at  Figure  8.6,  it  can  be  seen  that  four  passes  are  necessary  in 
this  example. 

The  process  is  simple,  and  is  widely  used. 

One  additional  complication  resides  in  the  actual  mechanism  of  the 
exchange. 

When  exchanging  A  and  B,  one  may  not  write 

A  -  B 
B  =  A 

as  this  would  result  in  the  loss  of  the  previous  value  of  A  (try  it  on  an 
example). 
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100>2: 
NO  CHANGE 


0 


■  1=4 

■  f  =  S 


10 
5 


2^0 
NO  CHANGt 


t=3 
■  I  --! 


0 


1-3 


0<  5 
SXCHANGEi 


0 


■  1-1 

■  1  =  2 


0<  10: 
EXCHANGE! 


© 


EXCHANGE  0 
END  OF  PASS  1 


0 


END  Of  PASS 


■  t  =  4 

■  (  =  5 


IQ0>2: 
NO  CHANGE 


0 


1=3 
\-4 


7<i: 
EXCHANGEI 


EXCHANGED 


0 


■  i=2 

■  1=3 


2<10: 
EXCHANGE 


100 


EXCHANGED 


1=1 
1=2 


2>0: 
NO  CHANGt 


END  OF  PASS  2 


Fig.  8.5:  Bubbie-Sort  Example:  Phases  1  to  12 
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to 


I  5 


m>  5 

NO  CHANGE 


0 


10 


SOQ 


5^2: 
NO  CHANGE 


16 


10 


100 


iO>5: 
NO  CHANGE 


to 


100 


1  =  3 
i  =  4 


EXCHANGE' 


© 


10 


100 


1=1 

1=2 


2>0: 
NO  CHANGE 

END  OF  PASS  ; 


10 


100 


i  =  2 
)  =  3 


5>  2: 
NO  CHANGE 


20 


0 

3 

5 

— 

10 

100 

© 

0 

2 

5 

10 

100 

S00>  10: 

NO  CHANGE 
© 

0 

2 

^  

5 

10 

100 

2>Q: 

NO  CHANGE 

0 
END 

1  =  5 


1=1 
1  =  2 


Fig.  8,6:  Bubble-Sort  Example:  Phases  13  to  21 

The  correct  solution  is  to  use  a  temporary  variable  or  location  to  pre- 
serve the  value  of  A: 

TEMP  =  A 
A  =  B 
B  =  TEMP 

It  works  (try  it  on  an  example).  This  is  called  a  circular  permutation. 

This  is  the  way  all  programs  implement  the  exchange.  This  technique 
is  illustrated  on  the  flowchart  of  Figure  8.7. 
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V  

EXCHANGED  =  0 


GET  NUMBER  OF 
ELEMENTS  N 
I  =N 


Fig.  8.7:  Bubble-Sort  Flowchart 
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EXCHANGE/NOT 


IX 


PTR 


NEXT 


COUNT 


CURRENT 


LIST 


COUNT 


Fig.  8.8:  Bubble- Sort 


The  register  and  memory  assignments  are  shown  on  Figure  8.8,  and 
the  program  is; 

BUBBLE      LD     (TEMP),  HL        TEMP  =  (HL) 

AGAIN        LD     IX,  (TEMP)         IX  =  (HL) 

RES   FLAG,  H  EXCHANGED  FLAG  =0 

LD     B,  C 
DEC  B 

NEXT  LD     A,  (IX) 

LD     D,  A  CURRENT  ENTRY 

LD     E,  (IX+1)  E  =  NEXT  ENTRY 

CP    E  COMPARE 
JR     NC,  NOSWITCH  GO  TO  NOSWITCH  IF 

CURRENTS  NEXT 

XCHANGE  LD     (IX),  E  STORE  NEXT  INTO 

CURRENT 

LD     (IX  +  1),  D  STORE  CURRENT  INTO 

NEXT 

SET   FLAG,  H  EXCHANGED  FLAG  =  1 
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NOSWITCHINC  IX 

DJNZ  NEXT 


NEXT  ENTRY 

DEC  B.  CONTINUE  UNTIL 

ZERO 

EXCHANGED  =  1? 
RESTART  IF  FLAG=i 


BIT    FLAG,  H 
JR      NZ,  AGAIN 
RET 


SUMMARY 

Common  utility  routmes  have  been  presented  m  this  chapter  which 
use  combinations  of  the  techniques  we  have  described  in  the  previous 
chapters.  They  should  allow  you  to  start  designing  your  own  programs 
now.  Many  of  these  routines  have  used  a  special  data  structure,  the 
tabic.  Other  possibilities  exist  for  structuring  data,  and  will  now  be  re- 
viewed. 
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DATA  STRUCTURES 

PART  I  —  THEORY 


INTRODUCTION 

The  design  of  a  good  program  involves  two  tasks:  algorithm  design 
and  dala  structures  design.  In  most  simple  programs,  no  significant 
data  structures  are  involved,  so  the  main  objective  in  learnmg  program- 
ming is  designmg  algorithms  and  coding  them  efficiently  m  a  given 
machine  language.  This  is  what  we  have  accomplished  here.  However, 
designmg  more  complex  programs  also  requires  an  understanding  of 
data  structures.  Two  data  structures  have  already  been  used  through- 
out the  book;  the  table  and  the  stack.  The  purpose  of  this  chapter  is  to 
present  other,  more  general,  data  structures  that  you  may  want 
to  use.  This  chapter  is  completely  independent  of  the  microprocessor, 
or  even  the  computer,  selected.  It  is  theoretical  and  involves  the  logical 
organization  of  data  tn  the  system.  Specialized  books  exist  on  the  topic 
of  data  structures,  just  as  specialized  books  exist  on  the  subject  of 
efficient  multiplication,  division  or  other  usual  algorithms.  This 
chapter,  therefore,  will  be  limited  to  essentials  only.  It  does  not  claim 
to  be  complete.  The  most  common  data  structures  will  now  be  reviewed. 

POINTERS 

A  pointer  is  a  number  which  is  used  to  designate  the  location  of  the 
actual  dala.  Every  pointer  is  an  address.  However,  every  address  is  not 
necessarily  called  a  pointer.  An  address  is  a  pointer  only  if  it  points  at 
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some  type  of  data  or  at  structured  information.  We  have  already  en- 
countered a  typical  pointer:  the  stack  pointer,  which  points  to  the  top 
of  the  stack  (or  usually  just  over  the  top  of  the  stack).  We  will  see  that 
the  stack  is  a  common  data  structure,  called  an  LIFO  structure. 

As  another  example,  when  using  indirect  addressmg,  the  mdirect  ad- 
dress is  always  a  pointer  to  the  data  that  one  wishes  to  retrieve. 

Exercise  9.  h  Examine  Fig.  9.  L  At  address  15  tn  the  memory,  there  is  a 
pomter  to  Table  T.  Table  T starts  a!  address  500.  What  are  the  actual 
contents  of  the  pointer  to  T? 


—       POINTER  TO  T  — 

TABtE  T 

Fig.  9.1:  An  Indirection  Pointer 

LISTS 

Almost  all  data  structures  are  organized  as  lists  of  various  kinds. 
Sequential  Lists 

A  sequential  list,  or  table,  or  block,  is  probably  the  simplest  data 
structure,  and  is  one  that  we  have  already  used.  Tables  are  normally 
ordered  in  function  of  a  specific  criterion,  such  as  alphabetical  ordermg 
or  numerical  ordering.  U  is  then  easy  to  retrieve  an  element  in  a  table, 
usmg,  for  example,  indexed  addressmg,  as  we  have  done.  A  block  nor- 
maliy  refers  to  a  group  of  data  whsch  has  definite  limits  but  whose  con- 
tents are  not  ordered.  It  may  contain  a  string  of  characters;  it  may 
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be  a  sector  on  a  disk;  or  it  may  be  some  logical  area  (called  segment)  of 
the  memory.  In  such  cases,  it  may  not  be  easy  to  access  a  random  ele- 
ment of  the  block. 

In  order  to  facilitate  the  retrieval  of  blocks  of  information,  directo- 
ries are  used. 

Directories 

A  directory  is  a  list  of  tables  or  blocks.  For  example,  the  file  system 
will  normally  use  a  directory  structure.  As  a  simple  example,  the  master 
directory  of  the  system  may  include  a  list  of  the  users'  names.  This  is  il- 
lustrated in  Figure  9.2.  The  entry  for  user  "John"  points  to  John's  file 
directory.  The  file  directory  is  a  table  which  contains  the  names  of  all  of 
John's  files  and  their  location.  This  is,  again,  a  table  of  poinlers.  In  this 
case,  we  have  just  designed  a  two-ievel  directory.  A  flexible  directory 
system  will  allow  the  inclusion  of  additional  intermediate  directories,  as 
may  be  found  convenient  by  the  user. 


USER  OmECIOBV 


john-5 

AiPHA 

Sigma 

Fig.  9,2:  A  Directory  Structure 

Linked  List 

In  a  system  there  are  often  blocks  of  information  which  represent 
data,  events,  or  other  structures  which  cannot  be  moved  around  eas- 
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ily.  If  ihey  could,  we  would  probably  assemble  them  in  a  table  in  order 
to  sort  or  structure  them.  The  problem  now  is  that  we  wish  to  leave 
them  where  they  are  and  still  establish  an  ordering  among  them  such  as 
first,  second,  third,  fourth.  A  linked  list  will  be  used  to  solve  this  prob- 
lem. The  concept  of  a  linked  list  is  illustrated  by  Figure  9.3.  On  the  il- 
lustration, we  see  that  a  list  pomter,  called  FIRSTBLOCK,  points  to  the 
begmning  of  the  first  block.  A  dedicated  location  within  Block  (  such 
as,  perhaps,  the  first  or  the  last  word  in  it,  contains  a  pomter  to  Block 
2,  called  PTRI.  The  process  is  then  repeated  for  Block  2  and  Block  3. 
Since  Block  3  is  the  last  entry  m  the  list,  PTR3,  by  convention,  either 
contains  a  special  "nil"  value,  or  points  to  itself,  so  that  the  end  of  the 
list  can  be  detected.  This  structure  is  economical,  as  it  requires  only  a 
few  pointers  (one  per  block")  and  frees  the  user  from  having  to  physi- 
cally move  the  blocks  in  the  memory. 


FIRST 
BLOCK 


BlOCKl 


BLOCK  2 


BLOCKS 


-  Z] 


Fig,  9.3:  A  Linked  List 

Let  us  examine,  for  example,  how  a  new  block  will  be  inserted.  This 
IS  illustrated  by  Figure  9.4.  Let  us  assume  that  the  new  block  is  at  ad- 
dress NEWBLOCK,  and  is  to  be  inserted  between  Block  (  and  Block  2, 
Pointer  PTRI  is  simply  changed  to  the  value  NEWBLOCK,  so  that  it 
now  points  to  Block  X,  PTRX  will  contain  the  former  value  of  PTRI, 
i.e.,  it  will  point  to  Block  2.  The  other  pointers  in  the  structure  are  left 
unchanged.  We  can  see  that  the  insertion  of  a  new  block  has  simply  re- 
quired updating  two  pointers  in  the  structure.  This  is  clearly  efficient. 

Exercise  9.2:  Draw  a  diagram  showing  how  Block  2  would  be  removed 
from  (his  structure. 


F!BST 

BLOCK  1 

BLOCK 

Q. 

BLOCK  X 


BLOCK2 


BLOCK  3 


Fig.  9.4:  Inserting  a  New  Block 
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Several  types  of  lists  have  been  developed  to  facilitate  specific  types 
of  access,  msertions,  and  deletions  to  and  from  the  list.  Let  us  examine 
some  of  the  most  frequently  used  types  of  linked  lists. 

Queue 

A  queue  is  formally  called  a  FIFO,  or  first-in-first-out  list.  A  queue 
is  illustrated  in  Figure  9.5.  To  clarify  the  diagram,  we  can  assume,  for 
example,  that  the  block  on  the  left  is  a  service  routine  for  an  output 
device,  such  as  a  printer.  The  blocks  appearing  on  the  right  are  the  re- 
quest blocks  from  various  programs  or  routmes,  to  print  characters. 
The  order  in  which  they  will  be  serviced  is  the  order  established  by  the 
waiting  queue.  U  can  be  seen  that  the  first  event  which  will  obtain  serv- 
ice is  Block  1,  the  next  one  Is  Block  2,  and  the  foliowmg  one  is  Block  3. 
!n  a  queue,  the  convention  is  that  any  new  event  arriving  in  the  queue 
will  be  inserted  at  the  end.  Here  it  will  be  inserted  after  PTR3.  This 
guarantees  that  the  first  block  to  be  inserted  m  the  queue  will  be  the 
first  one  to  be  serviced.  It  is  quite  common  m  a  computer  system  to 
have  queues  for  a  number  of  events  whenever  they  must  wait  for  a 
scarce  resource,  such  as  the  processor  or  some  input/output  device. 


SESViCE  ROUTINE 


Fig.  9.5:  A  Queue 
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Slack 

The  stack  structure  has  already  been  studied  in  detail  throughout  the 
book.  It  is  a  last-in-first-out  structure  (LIFO).  The  last  element  depos- 
ited on  top  is  the  first  one  to  be  removed.  A  stack  may  either  be  im- 
plemented as  a  sorted  block,  or  it  may  be  implemented  as  a  list.  Because 
most  stacks  m  microprocessors  are  used  for  high-speed  events,  such  as 
subroutmes  and  interrupts,  a  continuous  block  is  usually  allocated  to 
the  stack  instead  of  using  a  linked  list. 

Linked  List  vs.  Block 

Similarly,  the  queue  could  be  implemented  as  a  block  of  reserved 
locations.  The  advantage  of  using  a  continuous  block  is  fast  retrieval 
and  the  elimination  of  the  pointers.  The  disadvantage  is  that  it  is  usu- 
ally necessary  to  dedicate  a  fairly  large  block  to  accommodate  the 
worst-case  size  of  the  structure.  Also,  it  makes  it  difficult  or  impractical 
to  insert  or  remove  elements  from  within  the  block.  Since  memory  is 
traditionally  a  scarce  resource,  blocks  have  usually  been  reserved  for 
fixed-size  structures  or  structures  requiring  the  maximum  speed  of  re- 
trieval, such  as  the  slack. 

Circular  List 

"Round  robin"  is  a  common  name  for  a  circular  list.  A  circular  list  is 
a  linked  list  m  which  the  last  entry  points  back  to  the  first  one.  This  is  il- 
lustrated in  Figure  9.6.  In  the  case  of  a  circular  list,  a  current-block 
pointer  is  often  kept.  In  the  case  of  events,  or  programs,  waiting  for 
service,  the  current-event  pointer  will  be  moved  by  one  position  to  the 
left  or  to  the  right  every  time.  A  round  robin  usually  corresponds  to  a 
structure  in  which  all  blocks  are  assumed  to  have  the  same  priority. 
However,  a  circular  list  may  also  be  used  as  a  subcase  of  other  struc- 
tures simply  to  facilitate  the  retrieval  of  the  first  block  after  the  last 
one,  when  performing  a  search. 

As  an  example  of  a  circular  list,  a  polling  program  usually  goes  in  a 
round  robin  fashion,  mterrogating  all  peripherals  and  then  coming 
back  to  the  first  one. 

Trees 

Whenever  a  logical  relationship  exists  among  all  elements  of  a  struc- 
ture (this  IS  usually  called  a  syntax),  a  tree  structure  may  be  used.  A  strn- 
ple  example  of  a  tree  structure  is  a  descendant,  or  genealogical,  tree. 
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p 


EVENT  1 

CUBStN!  EveNI 


Fig.  9.6:  Round  Robin  is  Circular  List 


This  IS  illustrated  in  Figure  9.7.  It  can  be  seen  thai  Smith  has  two  chil- 
dren; a  son,  Robert,  and  a  daughter,  Jane,  Jane,  in  turn,  has  three 
children:  Liz,  Tom  and  Phil.  Tom,  in  turn,  has  two  more  children:  Max 
and  Chris.  However,  Robert,  on  the  left  of  the  illustration,  has  no  de- 
scendants. 

This  IS  a  structured  tree.  We  have,  in  fact,  already  encountered  an  ex- 
ample of  a  simple  tree  in  Figure  9.2.  The  directory  structure  is  a  two- 
level  tree.  Trees  are  used  to  advantage  whenever  elements  may  be  classi- 
fied according  to  a  fixed  structure.  This  facilitates  insertion  and  re- 
trieval, in  addition,  they  may  establish  groups  of  information  in  a 
structured  way  which  may  be  required  for  later  processing,  such  as  in  a 
compiler  or  interpreter  design. 


Fig,  9.7:  Genealogical  Tree 


Doubly-Linked  Lists 

Additional  links  may  be  established  between  elements  of  a  list.  The 
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simplest  example  is  the  doubly-linked  list.  This  is  illustrated  in  Figure 
9,8,  We  can  see  that  we  have  the  usual  sequence  of  links  from  left  to 
right,  plus  another  sequence  of  links  from  right  to  left.  The  goal  is  to 
allow  easy  retrieval  of  the  element  just  before  the  one  which  is  being 
processed,  as  weli  as  just  after  tt.  This  costs  an  extra  pointer  per  block. 


BLOCK  1 

a 
c 

a: 

BIOCK  2 

a: 

Dl 

a: 
a. 

SLOCK  3 

Fig.  9.8:  Doubly-Linked  List 


SEARCHING  AND  SORTING 

Searching  and  sortmg  elements  of  a  list  depends  directly  on  the  type 
of  structure  which  has  been  used  for  the  list.  Many  searching  algo- 
rithms have  been  developed  for  the  most  frequently  used  data  struc- 
tures. We  have  already  used  indexed  addressing.  This  is  possible  when- 
ever the  elements  of  a  table  are  ordered  in  function  of  a  known 
criterion.  Such  elements  may  then  be  retrieved  by  their  numbers. 

Sequential  searching  refers  to  the  linear  scanning  of  an  entire  block. 
This  is  clearly  inefficient  but  may  have  to  be  used  when  no  better  tech- 
nique is  available,  for  lack  of  ordering  of  the  elements. 

Binary,  or  logarithmic,  searching  attempts  to  find  an  element  in  a 
sorted  list  by  dividing  the  search  interval  in  half  at  every  step.  Assum- 
ing that  we  are  searching  an  alphabetical  list,  one  might  start,  for  exam- 
ple, m  the  middle  of  a  table  and  determine  if  the  name  we  are  looking 
for  is  before  or  after  this  point.  If  it  is  after  this  point,  we  will  eliminate 
the  first  half  of  the  table  and  look  at  the  middle  element  of  the  second 
half.  We  compare  this  entry  again  to  the  one  we  are  looking  for,  and  we 
restrict  our  .search  to  one  of  the  two  halves,  and  so  on.  The  maximum 
length  of  a  search  is  then  guaranteed  to  be  iogjn,  where  n  is  the  number 
of  elements  in  the  table. 

Many  other  search  techniques  exist. 

SECTION  SUMMARY 

This  section  was  intended  as  only  a  brief  presentation  of  usual  data 
structures  which  may  be  used  by  a  programmer.  Although  most  com- 
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mon  data  structures  have  been  organized  In  types  and  given  a  name,  the 
overall  organization  of  data  in  a  complex  system  may  use  any  combina- 
tion of  them,  or  require  the  programmer  to  invent  more  appropriate 
structures.  The  array  of  possibilities  is  only  limited  by  the  imagination 
of  the  programmer.  Similarly,  a  number  of  well-known  sorting  and 
searching  techniques  have  been  developed  for  coping  with  the  usual 
data  structures.  A  comprehensive  description  is  beyond  the  scope  of 
this  book.  The  contents  of  this  section  were  intended  to  stress  the  im- 
portance of  designing  appropriate  section  structures  for  the  data  to  be 
manipulated  and  to  provide  the  basic  tools  to  that  effect. 
Actual  programming  examples  will  now  be  presented  in  detail. 
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PART  II  —  DESIGN  EXAMPLES 


INTRODUCTION 

Actual  design  examples  will  be  presented  here  for  typical  data  struc- 
tures: table,  sorted  list,  linked  list.  Practical  searching  and  insertion  and 
deletion  algorithms  will  be  programmed  for  these  structures. 

The  reader  interested  in  these  advanced  programming  techniques  is 
encouraged  to  analyze  m  detail  the  programs  presented  in  this  section. 

However,  the  beginning  programmer  may  skip  this  section  initially, 
and  come  back  to  it  when  he  feels  ready  for  it. 

A  good  understanding  of  the  concepts  presented  in  the  first  part  of 
this  chapter  is  necessary  to  follow  the  design  examples.  Also,  the  pro- 
grams will  use  all  of  the  addressing  modes  of  the  Z80,  and  integrate 
many  of  the  concepts  and  techniques  presented  in  the  previous  chapters. 

Three  structures  will  now  be  introduced:  a  simple  list,  an  alphabetical 
list  and  a  linked-list  plus  directory.  For  each  structure,  three  programs 
will  be  developed:  search,  enter  and  delete. 

DATA  REPRESENTATION  FOR  THE  LIST 

Both  the  simple  list  and  the  alphabetic  list  will  use  a  common  repre- 
sentation for  each  list  element; 


3-byte  label  Data 
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ENTtEN 


TAB  BASE  / 


DATA 


lENGFHOF  ENTRY 


NUMBER  OF  ENTRIES 


EMTER  NEW  ELEMENf 


Fig.  9.9:  The  Table  Structure 


ELEMENT 


ELEMENT 
2 


LABEL 


1 

D 

C 

1 

•  lABEt 
) 

C 

c 

D 

DATA 


ENTLEN 


ENTIEN 


Fig  9.10:  Typical  List  Entries  in  the  Memory 
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Each  element,  or  "entry",  includes  a  3-byte  label,  and  an  n-byte  block 
of  data,  with  n  between  1  and  253,  Thus,  at  most,  each  entry  uses  one 
page  {256  bytes).  Within  each  list,  all  elements  have  the  same  length  (see 
Figure  9. 10).  The  programs  operating  on  these  two  simple  lists  use  some 
common  variable  conventions: 

ENTLEN  is  the  length  of  an  element.  For  example,  if  each  element 
has  10  bytes  of  data,  ENTLEN  =  3+10=13 
TABASE    is  the  base  of  the  list  or  table  in  the  memory 
POINTR     is  a  running  pomter  to  the  current  element 
OBJECT     is  the  current  entry  to  be  located,  inserted  or  deleted 
TABLEN    is  the  number  of  entries . 

AH  labels  are  assumed  to  be  distinct.  Changing  this  convention  would 
require  a  minor  change  in  the  programs. 


Fig.  9.11:  The  Simple  List 
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A  SIMPLE  LIST 

The  simple  iist  is  organized  as  a  table  of  n  elements.  The  elements  are 
not  sorted  (see  Figure  9.11).  When  searching,  one  must  scan  through 
the  list  until  an  entry  is  found  or  the  end  of  the  table  is  reached.  When 
inserting,  new  entries  are  appended  to  the  existing  ones.  When  an  entry 
is  deleted,  the  entries  in  higher  memory  locations,  if  any,  will  be  shifted 
up  to  keep  the  table  continuous. 

Searching 

A  serial  search  technique  is  used.  Each  entry's  label  field  is  compared 
in  turn  to  the  OBJECT'S  label,  letter  by  letter. 
The  running  pointer  POINTR  is  initialized  to  the  value  of  TABASE. 


Fig.  9.12:  Table  Search  Flowchart 
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The  search  proceeds  in  the  obvious  way,  and  the  corresponding  flow- 
chart is  shown  on  Figure  9.12.  The  program  appears  on  Figure  9.16 
at  the  end  of  this  section  (program  "SEARCH").  A  sample  run  of  the 
program  is  shown  in  Figure  9. 17, 

Inserting 

When  mserting  a  new  element,  the  first  available  memory  block  of 
(ENTLEN)  bytes  at  the  end  of  the  list  is  used  {see  Figure  9. 1 1). 

The  program  first  checks  that  the  new  entry  is  not  already  m  the  list 
(aii  labels  are  assumed  to  be  distinct  in  this  example).  If  not,  it  incre- 
ments the  list  length  TABLEN,  and  moves  the  OBJECT  to  the  end  of 
the  list.  The  corresponding  flowchart  is  shown  in  Figure  9. 13. 

The  program  is  shown  m  Figure  9.16.  It  is  called  "NEW"  and  resides 
at  memory  locations  0135  to  015E. 

The  index  register  lY  points  to  the  source,  HL  and  DE  are  destina- 
tion pointers. 


SAVE  OLD  TABIE  UNGIH 


y 


SNCREMENr  TABIE  lENGTH 


t 


POINT  AFTER 
END  Of  TABLE 


r 


SN5ERT  OBJECT 
END 


Fig.  9.13:  Table  Insertion  Flowchart 
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Deleting 

In  order  lo  delete  an  element  from  the  list,  the  elements  following  it 
m  the  list  at  higher  addresses  are  merely  moved  up  by  one  element  posi- 
tion. The  length  of  the  list  is  decremented.  This  is  illustrated  on  Figure 
9.14. 

The  corresponding  program  is  straightforward  and  appears  on  Fig- 
ure 9.16.  It  is  called  "DELETE",  and  resides  at  memory  addresses 
OlSFto  0187.  The  flowchart  is  shown  in  Figure  9.15. 

Memory  location  TEMPTR  is  used  as  a  temporary  pointer  pointing 
to  the  element  to  be  moved  up. 

Dunng  the  transfer,  POINTR  always  points  to  the  "hole"  in  the  list. 
I.e.,  the  destination  of  the  next  block  transfer. 

The  Z  flag  is  used  to  indicate  a  successful  deletion  upon  exit. 

Note  how  the  LDIR  instruction  is  used  for  efficient  automated  block 
transfer  (refer  to  address  0178  in  Figure  9.16). 

LD  A.  B  BLOCK  COUNTER 

NEWBLOC     LD  BC,  (ENTLEN)     BLOCK  LENGTH 
LDIR 

DEC  A 

JP  NZ,  NEWBLOC 


BEFORE 


AFTER 


0 

0 

© 

0 

© 

© 

DELETE  ► 

0 

^  MOVE 

© 

TEMPTR   

© 

© 

© 

^  MOVE 

Fig.  9.14:  Deleting  an  Entry  (Simple  List) 
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FIND  ENTRY 


DECREMENT  TABLE  LENGTH 

I 


FINDNBR  OF  ENTRIES 
AFTER  OB  JECTIN  TABLE 


EXIT 


SHIFT  ONE  ENTRY  UP 

1 

DECREASE  COUNT  OF 
ENTRIES  REMAINING 
AFTER  THE  ONE  SHIFTED 


NO 


OUT 


Fig.  9,15:  Table  Deletion  Flowchart 
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0000 

ORG 

OlOOH 

t01B7! 

EWTLEH 

DL 

ENDER 

1 0IB9! 

TfiELEN 

DL 

EHBER+2 

t018fl> 

TfiBflSE 

DL 

ENDER+3 

(OIBC) 

TEMP 

BL 

ENBER+S 

0!00 

1600 

SEfiRCH 

Ltl 

11*0 

; CLEAR  0 

0102 

3AB90! 

LD 

rtt  <  TABLEH> 

! CHECK  FDR  A  ZERO  TABLE  LENGTH 

0105 

A7 

J  SET  FLAGS 

0104 

ca 

ffET 

Z 

0107 

17 

LD 

B  rA 

J  STAFF    TATil  F   1  FWATH 

oloa 

Dtl2flBA01 

LD 

I X  1  (  TftBflSE  J 

fPUT  BASE  ABDR*    IN  IX 

OiOC 

Dri7E00 

tOOF 

i.U 

fit  (.  IX+0 ) 

JCHECK  FIRST  LETTER  QF  ENTRY 

01  OF 

FDEEOO 

EF 

(lY+O) 

0112 

C22701 

JF 

NZtNEXTQHE 

0115 

DD7E01 

LB 

fCHECK   2tW  LETTER 

OllB 

FDBEOl 

CP 

(  lYU  ) 

OtlB 

€22701 

JF 

HZrHEXTONE 

01  !E 

tiIi7E02 

LB 

fir  (lXt2) 

: CHECK  3RB  LETTER 

012! 

FnBE02 

CP 

{I¥*2) 

0121 

Cfi3201 

JF 

Z.FOUNIl 

iEXIT    IE  ALL  LETteftS  HATCH 

0127 

05 

HEXTOHE 

PEC 

B 

iDECREHEHT  TABLE  tEHOTH  COUHTER 

01 2G 

CB 

RET 

2 

(EXIT   IF  AT  EMB  OF  TA&LE 

0129 

EtlSPB70! 

LB 

BE»<E!tILeH> 

;S6T    tx   TO  NEXT  EHTRV  ADDR, 

01211 

DDI? 

rtBIi 

IXi  DE 

012F 

C30C01 

JP 

LGDP 

;iRT  AOAIN 

0132 

I4FF 

FQUN& 

LU 

B • OFFH 

fSET  D  TO  SHOU    IX   CONTAINS  AlPllR. 

013V1 

C9 

RET 

*.<0F  ENTRY  IN  TABLE 

013S 

CtlOOOI 

CnLL 

SEARCH 

JSEE   IF  OBJECT    IS  THERE 

0138 

1 1 

INC 

f> 

013? 

CnSEOl 

JF 

Z iBUTE 

ilF  D  UfiS  FF.  EXIT 

0I3C 

3(1890 1 

LD 

A> (TrtBLEH) 

013F 

SF 

LC 

Etrt 

;loab  e  uith  table  length 

0110 

3C 

INC 

A 

0111 

328901 

LD 

(TABLENltrt 

» INCREMENT  TABLE  LENGTH 

014^ 

1400 

LD 

tl.O 

0114 

2fl9fl01 

HL  r ( TABrtSE  > 

0119 

Eti1M701 

LB 

BCf  tENTLEN> 

*SET  B  to  LENGTH  OF  AN  ENTRY 

01  ID 

1J 

LD 

BrC 

OJ  1£ 

19 

f^BB 

HL  t  BE 

011F 

lOFB 

BJNZ 

LQOPE 

iADD  HL  TQ   ( ENTLEN:: TABLEN ) 

OISl 

ED1ilS701 

LB 

BCt (EMTLEN) 

01S5 

FD£5 

PUSH 

IT 

iHUME   IT  TO  BE 

0157 

Dl 

POP 

BE 

OlSB 

£B 

EX 

DEiHL 

OlS? 

Et>BO 

LBIR 

iHOUE  MEMORY  FROM  OBjeCT  TO  SHD 

0!5ti 

OlFFFF 

LB 

eC.OFFFFH 

i . .OF  TABLE 

015E 

C9 

□  UTE 

, 
i 

RET 

013F 

cnoooi 

j 

SELETE 

COLL 

SEARCH 

rFIND  ENTRY   TO   BE  DELETED 

0142 

11 

I> 

r :3l:i^   iv    li    wh3  ruunt' 

0143 

C29401 

JF 

0144 

3rta901 

LIS 

A  1  [ TABLEN  > 

014' 

3ti 

Dec 

A 

Gi6fl 

323901 

1  TfiBLEH  J  r  A 

ni4D 

OS 

PEC 

p 

!B  HQU~*   OF  ENTRIES  LEFT   IN  TABl 

016E 

Cfla301 

JP 

ZrEXIT 

AFTER  ONE  TO  BE  BELETEB 

017) 

[>DES 

PUSH 

IX 

iHOUE  IX  TO  BE 

0173 

Bl 

PDP 

BE 

0171 

2ftB701 

LD 

HLt (ENTLEN) 

iSET  HL  ONE  ENTRY  AHEAD  OF  BE 

0173 

19 

flBP 

HL.BE 

0 1 7B 

?B 

LB 

AtB 

J  SET  BLOCK  COUNTER 

0179 

ED1Eia70l 

KEUW-BC 

LD 

BCt (ENTLEH) 

;SET  BLOCK  LENGTH  COUNTER 

017[t 

EDSO 

LBtiV 

(SHIFT   i   ENTRY  OF  TASLE 

017F 

311 

DEC 

A 

oiao 

C27901 

JP 

NZ.HEUBLaC 

i SHIFT  ANOTHER  BLOCK 

0183 

OlFFFF 

EXIT 

LP 

ECrOFFFFH 

iSHOU  THAT   IT  UAS  DONE 

Olfli 

€9 

OUT 

ft£T 

0137 

(0000 1 

EHIiER 

EH» 

Fig.  9.16:  Simple  List — The  Programs 
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STMBQL  TOBLE 


OEt-ETE 
LDPP 
OUT 
TEMP 


GIOC 

Diet 

OIBC 


EHPER 
LDOPE 
GtSTE 


01 B7 
011E 
OlSE 


HEM 
SEftRCH 


0135 
OSOO 


EXIT 

HEUBLO 

TABASE 


0103 
0179 
018ft 


FQUMP 

NEXTDN 

TftBLEN 


Fig.  9.16:  Simple  List—  The  Programs  (cont.) 


0132 
0127 
01B9 


Display  Memory 


LUllngof  Objtcu 
with  iheir  locations 
In  memory 


-DM3Q0 

0300 

S3 

■tF 

IE 
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31 

31 

31 

31 

-31 

31 

31 

31 

31 

00 

00 

00 

5DN111111111I . . , 

0310 

AA 

■tl 
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32 

32 

32 
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32 

32 

3^ 

00 

00 

00 
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0320 

flD 

■IF 

AH 

33 

33 

33 
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33 

33 

33 

00 

oo 

00 

HGH3333333333 . . . 
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55 

■SE 

A3 

34 

34 

3-! 

34 

34 

-34 

34 

34 

34 

34 

00 

00 

00 

lJ(iC44444444'14  .  .  . 

03A0 

Ai 

IE 

SA 

35 

35 

35 

35 

35 

-35 

35 

35 

35 

3S 

00 

00 

00 

AHT555555555S . . . 

03S0 

00 

00 

00 

00 

00 

00 

00 

00 

-00 

00 

00 

00 

00 

00 

00 

00 

O3A0 

00 

00 

00 

00 

00 

00 

00 

00 
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00 

00 

00 

00 

00 

00 

00 

0370 

00 

00 

00 

00 

00 

00 

00 

00 

-00 

00 

00 

00 

00 

00 

oo 

00 

-SY 

V-0000  300 


Set  lY  to  0300H  (pointer  to  OBJECT) 


-G193/154 

p=oi96  0194'  Run 'INSERT' 

Table  confi  guraMon 
nUcT  procram  run 

-DH400 

0400    53  4F  4S  31  31  31  31  31-31  31  31  31  31  00  00  00  SOMll II Ullll . . 

0410     00  00  00  00  00  00  00  00-00  00  00  00  00  00  00  00   

0420     00  00  00  00  00  00  00  00-00  00  00  00  00  00  00  00   

0430     00  00  00  00  00  00  00  00-00  00  00  00  00  00  00  00   

0440     00  00  00  00  00  00  00  00-00  00  00  00  00  00  00  00   

0450     DO  00  00  00  00  00  00  OO-OO  00  00  00  00  00  00  00  ,  

0460   00  oo  00  00  00  00  00  00-00  00  00  00  00  00  00  00   

0470   00  00  00  00  00  00  oo  oo-oo  oo  oo  oo  oo  oo  oo  oo  ,  


-ST 

T=0300  310 


Set  lY  to  0310H  (next  OBJECT) 


-G!93/19fi 

p=oi94  0196-  Run 'INSERT' 


-PM400 

0400 

53 

4F 

4e 

31 

0110 

32 

32 

32 

32 

0420 

00 

00 

00 

DO 

0430 

00 

DO 

00 

00 

0440 

00 

00 

00 

00 
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00 

00 

00 

00 

0460 

00 

00 

00 

00 
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00 

00 

00 

00 
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32  32  32  32-32  32 
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00  00  00  00-00  00 
00  00  00  00-00  00 
00  00  00  00-00  00 

00  00  00  00-00  00 
00  00  00  00-00  00 


31  31  31  44  41  44 
00  00  00  00  00  00 
00  00  00  00  00  00 
00  00  00  00  00  00 
00  00  00  00  00  00 
00  00  00  00  00  00 
00  00  00  00  00  00 
00  00  00  00  00  00 


Tabfe  configuration 
after  second  insert 

SONI  !  Ill  11  UlDflD 


-riM400 

0400 

53 

4F 

4E 

31 

O410 

32 

32 

32 

32 

0420 

34 

34 

34 

34 
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33 

33 

33 

0440 

35 

00 

00 

00 

0450 

00 

00 

00 

00 

04A0 

00 

00 

00 

00 
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00 

00 

00 

00 

(More  insertions) 


31  31  31   31-31  31 

32  32  32  32-32  32 
34  34  34  4D-4F  4D 
4!  4E  54  35-35  35 
00  00  00  00-00  00 
00  00  00  00-00  DO 
00  00  00  00-00  00 
00  00  00  00-00  00 


31    31    31    44   41  44 

55  4E   43   34  34  34 

33  33  33  33  33  33 

35  35  35  33  33  35 

00  00  00  00  00  00 

00  00  00  00  00  00 

00  00  00  00  00  00 

00  00  00  00  00  00 


TflWe  canHeuratiDn 
aUnr  aevcrat  tnscrJs 

BDNllllllllllDflP 
2222222222UNC444 
4444444H0H333333 
3333flNT555555555 
5  


Fig.  9.17:  Simple  List— A  Sample  Run 
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^aIt:  fiuappHrcni 
change  m  table 

Satnil  1 1  III  lltirtit 
2222222222UNC444 
4Ji44444rtNT5555S5 
SS5SrtNTS55555555 
5  


-BM1D7SS 

01B9   03  — •  Memory  location  'TABLEN'  —  shows  true  ienelh  of  table 

-GI90/193 

p=oi73  0193'      Run 'SEARCH' for  deleted  Object 

-Dshows  that  Object  was  not  found 


-jir; 

Z     N      rt=.55  tlC=O0FF  [C^OOOB  !tt=04-H   S"^0100  f^Ol-JS  0193-   MLt,  013S 

ft'=oo  B'=oooo  ri'=oooo  ir=oooo  x=04in  Y=a34o  r^oo  (0!3s-i 


Fig.  9.17:  Simple  List—  A  Sample  Run  (cont.l 
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ALPHABETIC  LIST 

The  alphabetic  list,  or  "table,"  unUke  the  previous  one,  keeps  all 
Its  elements  sorted  in  alphabetic  order.  This  allows  the  use  of  fast- 
er search  techniques  than  the  linear  one.  A  binary  search  is  used  here. 

Searching 

The  search  algorithm  is  a  classic  binary  search.  Let  us  recall  that 
the  technique  is  essentially  analogous  to  the  one  used  to  find  a  name  in 
a  telephone  book.  One  usually  starts  somewhere  in  the  middle  of  the 
book,  and  then,  depending  on  the  entries  found  there,  goes  either  back- 
wards or  forward  to  find  the  desired  entry.  This  method  is  fast  and 
reasonably  simple  to  implement. 

The  binary  seach  flowchart  is  shown  in  Fig.  9.18,  and  the  program  is 
shown  in  Fig.  9.23. 

This  list  keeps  the  entries  in  alphabetical  order  and  retrieves  them  by 
using  a  binary  or  "logarithmic"  search.  An  example  is  shown  in  Figure 
9.19.  The  search  is  somewhat  complicated  by  the  need  to  keep  track  of 
several  conditions.  The  major  problem  to  be  avoided  is  searching  for  an 
object  that  is  not  there.  In  such  a  case,  the  entries  with  immediately 
higher  and  lower  alphabetic  values  could  be  alternately  tested  forever. 
To  avoid  this,  a  flag  is  maintained  in  the  program  to  preserve  the  value 
of  the  carry  flag  after  an  unsuccessful  comparison.  When  the  INCMNT 
value,  which  shows  by  how  much  the  pointer  will  next  be  incremented 
reaches  a  value  of  "1".  another  flag  called  "CLOSENOW",  which  we 
will  abbreviate  to  "CLOSE",  is  set  to  the  value  of  the  COMPRES 
flag  Thus,  since  all  further  increments  will  be  "1",  if  the  pointer  goes 
past  the  point  where  the  object  should  be,  COMPRES  will  no  longer 
equal  CLOSE  and  the  search  will  terminate.  This  feature  also  enables 
the  NEW  routine  to  determine  where  the  logical  and  physical  pointers 
are  located,  relative  to  where  the  object  will  go. 

Thus,  if  the  OBJECT  searched  for  is  not  in  the  table,  and  the  running 
pointer  is  mcremented  by  one,  the  CLOSE  flag  will  be  set.  On  the  next 
pass  of  the  routine,  the  result  of  the  comparison  will  be  opposite  to  the 
previous  one.  The  two  flags  will  no  longer  match,  and  the  program  will 
exit  indicating  "not  found". 
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Fig.  9.18:  Binary  Search  Flowchart 
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(NEXT  TEST) 


DOWN  BV  1 


1 

-C        GO  PA51  END  > 

UPDATE  POiNIEns 

itNtBT) 

ClOStNOW  —  COMPBSS 

Fig,  9.18:  Binary  Search  Flowchart  (cont.) 
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The  other  major  problem  that  must  be  dealt  with  is  the  possibiHty  of 
runmng  off  one  end  of  the  table  when  adding  or  subtracting  the  incre- 
ment value.  This  is  solved  by  performing  a  test  "add"  or  "subtract" 
using  the  logical  pointer  and  length  value  which  record  the  actual  num- 
ber of  entries,  not  the  physical  positions  in  memory  used  by  the  physical 
pointers. 

Tn  summary,  two  flags  are  used  by  the  program  to  memorize  mfor- 
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Fig.  9.19:  A  Binary  Search 
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mation:  COMPRES  and  CLOSE.  The  COMPRES  flag  is  used  to  preserve 
the  fact  that  the  carry  was  either  "0"  or  "I"  after  the  most  recent  com- 
parison. This  determines  if  the  element  under  test  was  larger  or  smaller 
than  the  one  with  which  it  was  compared.  The  C  indicates  the  relation. 
Whenever  the  carry  C  was  "1",  and  the  element  was  smaller  than  the 
object  COMPRES  is  set  to  "I",  Whenever  the  carry  C  was  "0",  indi- 
cating that  the  element  was  greater  than  the  object,  COMPRES  will  be 
set  to"FF". 

The  second  flag  used  by  the  program  is  CLOSE.  This  flag  is  set  equal 
to  COMPRESS  when  the  search  increment  INCMNT  becomes  equal  to 
"I",  it  will  detect  the  fact  that  the  element  has  not  been  found  if 
COMPRES  is  not  equal  to  CLOSE  the  next  time  around. 

Other  variables  used  by  the  program  are: 

LOGPOS     which  indicates  the  logical  position  in  the  table 

{element  number) 
INCMNT    which  represents  the  value  by  which  the  running 

pointer  will  be  incremented  or  decremented  if 

the  next  comparison  fails 
TABLEN     represents  as  usual  the  total  length  of  the  list, 

LOGPOS  and  INCMNT  will  be  compared  to  TABLEN  in  order  to 
assure  that  the  limits  of  the  list  are  not  exceeded. 

The  program  called  "SEARCH"  is  shown  on  Figure  9.23.  It  resides 
at  memory  locations  0 100  to  01 CF,  and  deserves  to  be  studied  with  care, 
as  it  is  much  more  complex  than  m  the  case  of  a  linear  search. 

An  additional  complication  is  due  to  the  fact  that  the  search  interval 
may  at  times  be  either  even  or  odd.  When  it  is  odd,  a  correction  must 
be  introduced.  (It  cannot,  for  instance,  point  to  the  middle  element  of  a 
four-element  list.)  When  it  is  odd,  a  "trick"  is  used  to  point  to  the 
middle  element:  the  division  by  2  is  accomplished  by  a  right  shift.  The 
bit  "falling  off  into  the  carry  after  the  SRL  instruction  will  be  "1"  if 
the  interval  was  odd.  U  is  merely  added  to  the  pointer. 

The  OBJECT  is  then  matched  against  the  entry  m  the  middle  of  the 
new  search  interval.  If  the  comparison  succeeds,  the  program  exits. 
Otherwise  ("NOGOOD"),  the  carry  is  set  to  "0"  if  the  OBJECT  is  less 
than  the  entry.  Whenever  the  INCMNT  becomes  "1",  the  CLOSE  flag 
(which  had  been  initialized  to  "0")  is  then  checked  to  see  if  it  was  set.  If 
it  was  not,  it  gets  set.  If  it  was  set,  a  check  is  run  to  determine  whether  we 
passed  the  location  where  the  OBJECT  should  have  been  but  is  not. 
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Also  note  that  when  the  carry  was  "  1 " ,  the  running  pointer  will  point 
to  the  entry  below  the  OBJECT. 


Element  Insertion 

In  order  to  insert  a  new  element,  a  binary  search  is  conducted.  If  the 
element  is  found  in  the  table,  it  does  not  need  to  be  inserted.  {We 
assume  here  that  all  elements  are  distinct),  if  the  element  was  not  found 
in  the  table,  it  must  be  inserted  immediately  before  or  immediately  after 
the  last  element  to  which  it  was  compared.  The  value  of  the  COMPRES 
flag  after  the  search  indicates  whether  it  should  be  inserted  immediately 
before  or  immediately  afterwards.  All  the  elements  following  the  new 
location  where  it  is  going  to  be  placed  are  moved  down  by  one  block 
position,  and  the  new  element  is  inserted. 


BEFORE 


ARER 


TABASE- 


ABC 


ABC 


BAT 


SAC 


—  NEW 

ELEMENT 


TAR 


BAT 


ZAP 


TAR 


ZAP 


OBJECT  - 


BAC 


MOVE  DOWN 


Fig.  9.20:  Insert:  "BAC" 
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The  insertion  process  is  iilusErated  in  Figure  9.20,  and  the  corre- 
sponding program  appears  in  Figure  9,23. 

The  program  is  called  NEW,  and  starts  at  memory  location  01  DO. 
Note  that  the  automated Z80  instructions  LDDR  and  LDIR  are  used  for 
efficient  block  transfers. 

Element  Deletion 

Similarly,  a  binary  search  is  conducted  to  find  the  object.  If  the 
search  fails,  It  does  not  need  to  be  deleted,  if  the  search  succeeds,  the 
element  is  deleted,  and  all  the  followmg  elements  are  moved  up  by  one 
block  position.  A  corresponding  example  is  shown  m  Figure  9.21,  and 
the  program  appears  in  Figure  9.23.  The  flowchart  is  shown  in  Fig. 
9.22. 

The  program  is  called  "DELETE"  and  resides  at  address  022i . 
A  sample  run  of  the  above  programs  is  shown  in  Fig.  9.24, 
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Fig.  9.21:  Delete  "BAC" 
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Fig.  9.22:  Deletion  Flowchart  (Alphabetic  List) 
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I.I' 

At  t  TAl'!.i:N5 

;  inff.fhkhT  inni.c  s.Enr.TH 

0219 

3C 

INF 

ft 

0210 

32'li;02 

l.!i 

(  fAiiLFN)  .ft 

021  n 

OlFFFF 

LI' 

STrOFFFFH 

JFiHOU   THAT    IT  UAG  IlllNE 

0220 

r.9 

nil? 

RF! 

Fig.  9.23:  Binary  Search  Program  (cont.) 
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0221 

CDOOOi 

DELETE 

CALL 

SEARCH 

fGET  flPDRESS  DP  OBJECT 

1  4 

IHC 

D 

iSEE   IF  OBJECT  IS 

THERE 

0225 

CA1702 

JP 

ZjOUTE 

03:?  8 

ED5Tf4r02 

LP 

C€<  teHTLEIJ! 

EX 

DErHL 

022D 

1? 

npD 

HLiBE 

ilsE   IS  LQE.    OF  OBJECT,    HL  IS 

022E 

3ft1C02 

LD 

At!TAE!LEHl 

,,,DNE  ENTRY  DEOWE 

90 

SUP 

if 

rSEE  HOU  MflNY  ENTRIES  ARE  LEFT 

0232 

Cfi3F02 

JP 

z.uauNTflP 

023S 

EDI  6-1^02 

SHIFTIfj 

LD 

023T 

ElttlO 

;SH!FT  DOWN   1   ENTRY  LENGTH 

023B 

3tl 

DEC 

fi 

023E: 

C23S02 

JP 

023F 

3A0e02 

LD 

A 1  <  TftBi.  EN  > 

SDECREHENT  TABLE 

LENGTH 

0242 

3D 

DEC 

0213 

324C02 

LD 

I TA&LEH  J  1 A 

02t6 

BCrOFFFFH 

iSHDU   THAT  ACTION 

UAS  TfiKEN 

OUTE 

RET 

o;4fi 

1 0000 i 

EHDED 

EHtl 

STHBOL  TABLE 

flOCEM 

01C9 

flDDIT 

0!96 

CL05EN  021A 

COMPRE  02HB 

DELETE  0221 

DOUHTfi  023F 

ENDED 

ENTLEH  02flF 

ENTRY       01  IE 

FQUND  OIBC 

HISIBE  OlEB 

INSERT 

02ac 

HOUEM  02O1 

HULT  OlEC 

HEM          01  BO 

NEXTES  Oli? 

NBGOOB 

0112 

NOTCLG  0163 

NOTFDU  OIBA 

OUT  0220 

OUTE 

0249 

REftLCL 

OiAF 

SEARCH  0100 

SETUP  016E 

SHIFT  I  0235 

TflBflSE  021D 

TflELEN 

<I24C 

TESTS  0149 

TDDHIG  OlftS 

TOOUtlH  01B5 

Fig.  9.23:  Binary  Searcii  Program  (cont.) 


LINKED  LIST 

The  linked  list  is  assumed  to  contain,  as  usual,  the  three  alphanu- 
meric characters  for  the  label,  followed  by  one  to  250  bytes  of  data,  fol- 
lowed by  a  two-byte  pointer  which  contains  the  starting  address  of  the 
next  entry,  and  lastly  followed  by  a  one-byte  marker.  Whenever  this 
one-byte  marker  is  set  to  "1",  it  will  prevent  the  insert-routine  from 
substituting  a  new  entry  in  the  place  of  the  existing  one. 

Further,  a  directory  contains  a  pointer  to  the  first  entry  for  each  let- 
ter of  the  alphabet,  m  order  to  facilitate  retrieval.  It  js  assumed  in  the 
program  that  the  labels  are  ASCII  alphabetic  characters.  All  pointers  at 
the  end  of  the  list  are  set  to  a  NIL  value  which  has  been  chosen  here  to 
be  equal  to  the  table  base,  as  this  value  should  never  occur  within  the 
linked  list. 

The  insertion  and  the  deletion  programs  perform  the  obvious  pointer 
manipulations.  They  use  the  flag  INDEXED  to  indicate  if  a  pointer 
pointing  to  an  object  came  from  a  previous  entry  in  the  list  or  from  the 
directory  table.  The  corresponding  programs  are  shown  in  Figure  9.29. 

The  data  structure  is  shown  in  Figure  9.25. 
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-tIMIO!) 

0100  00 

Oflli>  01) 

on;!!  00 

0130  00 

Olio  00 

0150  OO 

04iO  00 

O4?0  00 


(!0  00  00 

00  00  00 

00  00  00 

00  00  00 

00  00  00 

00  00  00 

00  00  00 

00  00  00 


00  00  00 
00  00  flO 

00  00  00 

00  00  00 

00  00  00 

00  HO  GO 

00  00  00 

00  00  00 


00  -00  00 

00-00  00 

00-00  00 

00-00  00 

00-00  00 

00-00  00 

00-00  00 

00-00  00 


00  00  00 

00  00  00 

00  00  00 

00  00  00 

00  00  00 

00  00  00 

00  00  00 

00  00  00 


OO  00  on 

00  00  00 
00  00  00 
00  00  00 
00  00  00 
00  00  00 
00  00  00 
00  00  00 


UMfnn  r)f  Oh  [CL'l>i 

-M300  '""'™'''^ 

0300     33   IF  IE  31  31  3J    3J  31    31  3J  31  31    3!  00  00  00  SON! ! ! n ! ! SSI . 

03I0        A!  1J1  3;  33  3v.  ^v.  ^'.•-i?  J'/  3^  3?  3?  00  00  00  hAri?3^:!:;:;:L?,;2 . 

03:'0     1(1  IF  111  33  33  33  33  33-33  33  33  33  33  00  00  00  MQtt3333333333 . 

0330     fjS  AE  13  31  31  31   31  34-3'i  SA  34  31   34  00  00  00  UHC141 4444444 , 

0310     11    4!;  S4  35  3r,  3!;  3;,  3S-35  35  35  3K  3n  00  00  00  rtHTSSSS5SSS5S. 

OJ^'O     00  00  00  00  00  00  00  00-00  00  00  00  00  00  00  00  ,4....  

0360     DO  00  00  00  "0  00  00  00-00  00  00  00  00  00  00  00   

03V0     00  00  00  00  00  00  00  00-00  00  00  00  00  00  00  00   

-BY  , 

Y-0000  3;?0  I 

-G2i3,'2<i/,  J 


Run  -INSKRT' 


-KrtlOO 

fllflC 

4 II 

4F 

4  0 

3  3 

04  iO 

00 

00 

00 

00 

oiro 

OO 

00 

00 

00 

0130 

00 

00 

00 

00 

0110 

00 

00 

00 

00 

0450 

00 

00 

on 

00 

04A0 

00 

00 

00 

00 

0170 

OO 

00 

00 

00 

33    33  33   .33-33  33 

00  00  00  00-00  00 

00  00  00  00-00  00 

00  00  00  00-00  00 

00  00  00  00-00  00 

00  00  00  00-00  00 

00  00  00  00-00  00 

00  00  00  00-00  00 


33  33  33  00  00  00 
00  00  00  00  00  00 
00  00  00  00  00  00 

00  00  00  00  00  no 
00  00  at)  00  00  00 

00  00  00  00  00  00 
00  00  00  DO  00  00 
00  00  GO  00  OO  00 


MQM3333333333. . . 


-sr  , 
r-03^0  310  f 

G-.w-As     J   Run 'INSERT' on  another  Object 

:'-o:i.'.A  o:'/i6'j  Ustinj! oT iBble  afiri* 

inMrtjuti.  Nate:  iBblf 
(sliepl  alpfeabtllc 

3333333333  


-imioo 

0100 

41 

11 

44 

3? 

.12 

32 

32 

32 

-32 

32 

32 

32 

32 

m 

■!r 

411 

Q1S0 

33 

33 

33 

33 

33 

33 

33 

33 

-33 

33 

00 

00 

00 

00 

00 

00 

oi:;o 

00 

00 

00 

00 

00 

00 

00 

00- 

-00 

00 

DO 

00 

00 

00 

00 

00 

O430 

OO 

00 

00 

00 

00 

00 

00 

00- 

-00 

00 

nn 

00 

00 

00 

00 

00 

0440 

00 

00 

00 

00 

00 

00 

00 

00 

-00 

00 

00 

00 

00 

00 

00 

00 

OISO 

00 

00 

00 

00 

00 

00 

00 

00 

-00 

00 

00 

00 

00 

00 

00 

00 

04AO 

00 

00 

00 

Oi) 

00 

00 

00 

00 

-00 

on 

00 

00 

00 

00 

00 

00 

04  70 

00 

00 

00 

00 

00 

00 

00 

00. 

-00 

00 

00 

00 

00 

00 

00 

00 

■  '  *  (addilional  inserts)  '  '  ' 


Fig.  9.24:  Alphabetic  List— A  Sample  Run 
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Tabic  canflgunilloit 
isricr  all  Objects 

-BH100  hove  been  Wserlcil 
O^OO  11  AE  54  35  35  35  35  3S-35  3S  35  3S  3S  41  41  44  ftNT55S5555555DA[l 
0410  32  32  32  32  32  32  32  32-32  32  4D  4F  4[i  33  33  33  2222222222H0M333 
0420  33  33  33  33  33  33  33  S3-4F  4E  31  31  31  3!  3i  3S  3333333S0NS  U  t !  S 
0430  31  3!  31  31  S5  4E  43  34-34  34  34  34  34  34  34  34  U 1 11IHC444444444 
0440     34  00  00  00  00  00  00  00-00  00  00  00  00  00  00  00     4  ,  

0450   00  00  00  00  00  00  00  00-00  oo  oo  oo  oo  oo  oo  oo  ,  

0440     00  00  00  00  00  00  00  00-00  00  00  00  00  00  00  00   

0470   00  00  00  00  00  00  oo  oo-oo  oo  oo  oo  oo  oo  oo  oo   

-SY 

ir-0340  300 

-0240/243       ii„„  'SEARCH'  for  "SON"  (at address O30O) 

P'=02A3  0243' 


•Found 


N       fi=4E   BC-0401    Dfe=00'OB  HL=0427  S=0100  .P=0243  0263'    CALL  OlDO 
tl'~0O   B'=0000  D'=0000  H'.OOOO  X30427   T=0300   1=00  lOlDO- 


'  Address  of  Object  in  table 

(verify  in  Tabic  above  that  it  is  "SON") 


P'0269  0269' 


Run  'DELETE'  on  "SON' 


-Pn400 

0400 

41 

4E 

54 

35 

35 

35 

35 

35- 

-35 

35 

35 

35 

35 

44 

41 

44 

0410 

32 

32 

32 

32 

32 

32 

32- 

-32 

32 

40 

If 

■IB 

33 

33 

33 

0420 

33 

33 

33 

33 

33 

33 

33 

55- 

-4E 

43 

34 

34 

34 

34 

34 

34 

0430 

34 

34 

34 

34 

5S 

4E 

43 

34-34 

34 

34 

34 

34 

34 

34 

34 

0440 

34 

00 

00 

00 

00 

00 

00 

OO- 

-00 

00 

00 

00 

00 

!)D 

00 

00 

04S0 

00 

00 

00 

00 

00 

00 

00 

OO- 

-00 

00 

00 

00 

OD 

00 

00 

00 

0440 

00 

00 

00 

00 

00 

00 

00 

00- 

-00 

00 

00 

00 

00 

00 

00 

00 

0470 

00 

00 

00 

00 

00 

00 

00 

00- 

-00 

00 

00 

no 

00 

00 

00 

00 

Table  c&nn^uratjQTi 
aricrdclelion.  Nole: 
Ihel  VNC  WHS  shlflcll 
op.  The  iBst  UNC 
efiln'  musl  bt 
dis  regarded 

fiHT5555555555DftD 
2222222222HDh333 
3333333UHC444444 
4444UNC444444444 


Try  run  of  "SEARCH"  agam  (on  "SON") 


P=0263  0243' 


r—^ —  Not  found 

=fe  EC.0401    IlE-ITOn  HL=0427  S=0100  P=0243  0243'    CnLL  OltO 
»00   H'=0000  l}'=0000  H'"0000  X-0427   t  =  0300   1=00  (OiDO'l 


P-0244  0244 


Re-insert  Object  ("SON") 


canriGUrstiail. 
Compare  Id  Ihe  one 
prior  10  the 


-E1H400 

DELETE 

0400 

41 

4E 

54 

33 

35 

35 

35 

35- 

35 

35 

3S 

35 

35 

44 

41 

44 

fiNT555555S555nfiP 

0410 

33 

32 

33 

32 

32 

33 

32 

32- 

32 

32 

111 

4F 

4P 

33 

33 

33 

0420 

33 

33 

33 

33 

33 

33 

33 

53- 

4F 

4E 

31 

31 

31 

31 

31 

31 

3333333SDM11111! 

0430 

31 

31 

31 

31 

55 

4E 

43 

34- 

34 

34 

34 

34 

34 

34 

34 

34 

11  1 1LINC444444444 

0440 

34 

00 

00 

00 

00 

00 

00 

00- 

00 

00 

00 

00 

no 

00 

00 

00 

04SO 

00 

00 

00 

00 

00 

00 

00 

00- 

00 

00 

00 

00 

00 

00 

00 

00 

0440 

00 

00 

00 

00 

00 

00 

00 

00- 

00 

00 

00 

00 

00 

00 

00 

00 

0470 

00 

00 

00 

OB 

00 

00 

00 

00- 

00 

00 

OO 

00 

00 

00 

00 

00 

Shows  that  action  was  executed 


A=aS  EC=PFFF  re=0434  HS.n030D  SiOSOO  P=»02AA  0244' 
fl'.OO   i!'=00O0   D'=0000  H'^0000  Xi0427  T=0300  I=-00 


CALL  0221 


Fig.  9.24:  Alphabetic  List— A  Sample  Run  (cont.) 
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DiREaORY 


POINTCR 


"R" 


POINTIR 


POlNtiR 


Of 


N(L 


Nil 


Fig.  9,25:  Linked  List  Structure 


An  application  for  this  data  structure  would  be  a  computerized  ad- 
dress book,  where  each  person  is  represented  by  a  unique  three-ietter 
code  (perhaps  the  usual  initials)  and  the  data  fieid  contains  a  simplified 
address,  plus  the  telephone  number  (up  to  250  characters).  Let  us  exam- 
ine the  structure  in  more  detail.  The  entry  format  is: 


c 

!  1 

C  i   C  j  D 

D 

S5 

D 

P 

P 

O 

unique  label  data  (1  to  250  bytes)      pointer  to 

(ASCII)  next 


occupied 


As  usual  the  conventions  are: 

ENTLEN:    total  element  length  (in  bytes) 
TABASE:    address  of  base  of  list 

The  address  of  the  OBJECT  is  always  assumed  to  reside  in  the  lY  register 
prior  to  entering  the  program.  Here,  REFBASE  points  to  the  base  ad- 
dress of  the  directory,  or  "reference  table." 

Each  two-byte  address  within  this  directory  points  to  the  first  occur- 
rence of  the  letter  to  which  it  corresponds  in  the  list.  Thus,  each  group 
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of  entries  with  an  identical  first  letter  in  their  labels  actualiy  forms  a  sep- 
arate list  withm  the  whole  structure.  This  feature  facilitates  searching 
and  is  analogous  to  an  address  book.  Note  that  no  data  are  moved  dur- 
ing an  insert  or  delete.  Only  pointers  are  changed,  as  in  every  well- 
behaved  linked  list  structure. 

If  no  entry  starting  with  a  specific  letter  is  found,  or  if  there  is  no  en- 
try alphabetically  following  an  existing  one,  their  pointers  will  point  to 
the  beginning  of  the  table  (=  "NIL").  At  the  bottom  of  the  table,  by 
convention  a  value  is  stored  such  that  the  absolute  value  of  the  differ- 
ence between  it  and  "2"  is  greater  than  the  difference  between  "A" 
and  "Z",  This  represents  an  End  Of  Table  (EOT)  marker.  The  EOT 
value  is  assumed  here  to  occupy  the  same  amount  of  memory  as  a  nor- 
mal entry  but  could  be  just  one  byte  if  desired.  The  letters  are  assumed 
to  be  alphabetic  letters  m  ASCII  code.  Changing  this  would  re- 
quire changmg  the  constant  in  the  PRETAB  routine. 

The  end-of-table  marker  is  set  to  the  value  of  the  beginning  of  the 
table  ("NIL"). 

By  convention,  the  "NIL  pointers",  found  at  the  end  of  a  string,  or 
within  a  directory  location  which  does  not  point  to  a  string,  are  set  to 
the  value  of  the  table  base  to  provide  a  unique  identification.  Another 
convention  could  be  used.  In  particular,  a  different  marker  for  EOT 
results  in  some  space  savings,  as  no  NIL  entries  need  be  kept  for  non- 
existmg  entries. 

Insertion  and  deletion  are  performed  in  the  usual  way  (see  Part  I  of 
this  chapter)  by  merely  modifying  the  required  pointers.  The 
INDEXED  flag  is  used  to  indicate  if  the  pointer  to  the  object  is  in  the 
reference  table  or  another  string  element. 

Searching 

The  SEARCH  program  resides  at  memory  iocations  0100  to  0155 
an  uses  subroutine  PRETAB  at  address  01D2, 
The  search  principle  is  straightforward: 

1—  Get  the  directory  entry  corresponding  to  the  letter  of  the  alphabet 
m  the  first  position  of  the  OBJECT'S  label. 

2—  Get  the  pomter.  Access  the  element.  If  NIL,  the  entry  does  not 
exist. 

3—  If  not  NIL,  match  the  element  against  the  OBJECT.  If  a  match  is 
found,  the  search  has  succeeded.  If  not,  get  the  pointer  to  the  next  entry 
down  the  list. 

4 —  Go  back  to  2. 

An  example  is  shown  in  Figure  9.26. 
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0 

A-POINIER 

AAA 

\j 

ABC 

AZC 

B.  POINTER 

J' 

NIL 

iJ  itEPS  SEOUiHEDl 


(FOUfJOl 


Fig.  9.26:  Linked  List— A  Search 


Inserting 


The  insertion  is  essentially  a  search  followed  by  an  insertion  once  a 
"NIL"  has  been  found. 

A  block  of  storage  for  the  new  entry  is  allocated  past  the  EOT 
marker  by  looking  for  an  occupancy  marker  set  at  "available". 

The  program  is  called  "NEW"  in  Figure  9.29  and  resides  at  ad- 
dresses 0156  to  1A3.  An  example  is  shown  in  Figure  9.27. 


Fig.  9.27:  Linlced  List:  Example  of  Insertion 
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Deleting 

The  element  is  deleted  by  setting  its  occupancy  marker  to  "available" 
and  adjusting  the  pointer  to  it  from  the  directory  or  else  the  previous 
element. 

The  program  is  called  "DELETE",  and  resides  at  addresses  01A4  to 
OlDl. 

An  example  of  a  deletion  is  shown  in  Figure  9.28. 


NH 


D£lEt[ 


lAflERi 

DOC  POfnISB 

1  ^ 

1               OAf  1 

■■(XX.- 


NOrE  OAF  ii,  NOT  E5A$tD.  Sur  ■  fNVfS^BLE' 

Fig.  9.28:  Example  of  Deledon  (Linked  List) 
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!>  1  ^>'}n 

t  fi  !  i    •  1 

!■! 

'Oil  fi) 

!>l 

r  fiS'i  r-  t  I 

< Oi r n  1 

nF 

}  iii^i  h  \  f 

0  I  f  f  ■  1 

f  f  J  r  !  1  fi 

Fi| 

i  avi  r  !  ■> 

0 }  00 

M  00 

':tV,M:i'ii 

1  h 

n  T  'I 

A? 

1  ^ 

-3  ]  OA 

Ar. 

inr 

IJT  ^'0  1 

i  ii 

[  f  liUf    f\  Ji  *  r  A 

, 

f  IiIi.'Ot 

(  0!  i 

- 1  it  f    ("iIiJUv    ))[      f  NJtl  y    1  'f  1 1  H 1 F  !■ 

0 1  on 

! 

I  I' 

A  .  ^  fif  > 

'  MdUf     i  ■)  n  N  H"l-:   ilfIN  1 1  N  I  '1    T  II  Ml 

i)  1  0:1 

/if 

1  f! 

?    •  J* 

"■J  { or 

t 

!  Nf . 

F>! 

'If  off 

f  A 

1  ^ 

f"i  -  ^  !»!  ' 

0  |0t 

il  -' 

f  h 

H  .  A 

<}  |{5F 

fff 

onf 

i'hr ! 

I  > 

!f!'/r:oo 

A  .  f  I  I  1  •>  f 

il  mil.  r.T  1  zT:y  \  i  r?  if  !■:  nr  r?iH: 

)  1 1  -> 

rr- 

;si  r   !F    in  riM  rtrti:i'.t  f: 

0 1  f 

IF- 

o  M 

MfVE  OO 

it' 

d.'.  ,  f  I  V  (  PJ  > 

Jf^MMlTiM     (  IKS?    1  ri  f  I  f  ;!^ 

on  I' 

ri'iif  00 

i:f- 

iJ  t 

r'A:iF  0 1 

sr 

t>!  :m 

if 

ti^  ,  !jrn  J  rtf iMT' 

i>  1 

^  If 

;ri!rti  Akf           U  MF  F:ii 

y  I 

J^lO'F  01 

rr 

'  f  y  f  M 

0 !  :'c 

I'0.!rOt 

.n- 

i'.  'Ufa'tUtiii 

0  J 

,lr 

Hi  rNntrin (fill 

U  1  .'I'' 

I'i'/r  0,' 

!.  i' 

n  .  '  i  >■  t > 

JflMFII  OF'-f'    :iF<1i  1  h  }  If  f-'l 
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Fig.  9.29:  Linked  List— The  Programs  (cont.) 
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Fig.  9.30:  Linked  List —  A  Sample  Run  (cont.) 


SUMMARY 

The  beginning  programmer  need  not  concern  himself  yet  with  the 
details  of  data  structures  implementation  and  management.  However, 
efficient  programming  of  non-trivial  algorithms  requires  a  good  under- 
standing of  data  structures.  The  actual  examples  presented  in  this 
chapter  should  help  the  reader  achieve  such  an  understanding  and  solve 
ail  the  common  problems  encountered  with  reasonable  data  structures. 
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INTRODUCTION 

Al!  the  programs  we  have  studied  and  developed  so  far  have  been 
developed  by  hand  without  the  aid  of  any  software  or  hardware  re- 
source. The  only  improvement  over  straight  binary  coding  has  been  the 
use  of  mnemonic  symbols,  those  of  the  assembly  language.  For  effec- 
tive software  development,  it  is  necessary  to  understand  the  range  of 
hardware  and  software  development  aids.  It  is  the  purpose  of  this  chap- 
ter to  present  and  evaluate  these  aids. 

BASIC  PROGRAMMING  CHOICES 

Three  basic  alternatives  exist:  writing  a  program  in  binary  or  hexa- 
decimal, writing  it  in  assembly-level  language,  or  writing  it  m  a  high- 
level  language.  Let  us  review  these  alternatives. 

Hexadecimal  Coding 

The  program  will  normally  be  written  using  assembly  language  mne- 
monics. However,  most  low-cost,  one-board  computer  systems  do  not 
provide  an  assembler.  The  assembler  is  the  program  which  will  auto- 
matically translate  the  mnemonics  used  for  the  program  into  the  re- 
quired binary  codes.  When  no  assembler  is  available,  this  translation 
from  mnemonics  into  bmary  must  be  performed  by  hand.  Binary  is 
unpleasant  to  use  and  error-prone,  so  that  hexadecimal  is  normally 
used.  It  has  been  shown  in  Chapter  1  that  one  hexadecimal  digit  will 
represent  four  binary  bits.  Two  hexadecimal  digits  will,  therefore,  be 
used  to  represent  the  contents  of  every  byte.  As  an  example,  the  table 
showing  the  hexadecimal  equivalent  of  the  Z80  instructions  appears  in 
the  Appendix. 
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In  short,  whenever  the  resources  of  the  user  are  Similed  and  no  assem- 
bler IS  available,  he  will  have  to  translate  the  program  by  hand  into  hex- 
adecimal. This  can  reasonably  be  done  for  a  small  number  of  mstruc- 
lions,  such  as,  perhaps,  10  to  100.  For  larger  programs,  this  process  is 
tedious  and  error-prone,  so  that  ii  tends  not  to  be  used.  However,  near- 
ly a!!  single-board  mscrocomputers  require  the  entry  of  programs  \n 
hexadecimal  mode.  They  are  not  equipped  with  an  assembler  and  a  full 
alphanumeric  keyboard,  in  order  to  limit  their  cost. 

in  summary,  he.xadecimai  coding  is  not  a  desirable  way  to  enter  a 
program  in  a  computer.  It  is  simply  an  economical  one.  The  cost  of  an 
assembler  and  the  required  alphanumeric  keyboard  is  traded-off 
against  increased  labor  required  lo  enter  the  program  in  the  memory. 
However,  this  does  not  change  the  way  the  program  itself  is  wntlen. 
The  program  is  sfil!  wnnen  in  ossein b/y-level  language  so  thai  it  can  be 
examined  by  the  human  programmer  and  be  meaningful. 


Assembly  Language  Programming 

Assembly-level  programming  covers  both  programs  that  may  be 
entered  in  hexadecimal  and  those  that  may  be  entered  in  symbolic 
assembly-level  form  jn  the  system.  Let  us  now  examine  the  entry  of  a 
program  directly  m  its  assembly  language  representation.  An  assembler 
program  must  be  available.  The  assembler  will  read  each  of  the  mne- 
monic instructions  of  the  program  and  translate  it  into  the  required  bit 
pattern  using  i  to  5  bytes,  as  specified  by  the  encoding  of  the  instruc- 
tions, in  addition,  a  good  assembler  will  offer  a  number  of  additional 
facilities  for  writing  the  program.  These  will  be  reviewed  in  the  seciion 
on  the  assembler  below.  In  particular,  direclives  are  available  which 
will  modify  the  value  of  symbols.  Symbolic  addressing  may  be  used  and 
a  branch  to  a  symbolic  location  may  be  specified.  During  the  debugging 
phase,  when  a  user  may  remove  or  add  instructions,  it  will  not  be  neces- 
sary 10  rewrite  the  entire  program  if  an  extra  instruction  is  inserted  be- 
tween a  branch  and  the  point  to  which  it  branches,  as  long  as  symbolic 
labels  are  used.  The  assembler  will  take  care  of  automatically  adjusting 
all  the  labels  during  the  translation  process.  In  addition,  an  assembler 
allows  the  user  to  debug  his  program  in  symbolic  form.  A  disassembler 
may  be  used  to  examine  the  contents  of  a  memory  location  and  recon- 
struct the  assembly-level  instruction  that  it  represents.  The  various  soft- 
ware resources  normally  available  on  a  system  will  be  reviewed  below. 
Let  us  now  examine  the  third  alternative. 
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Fig.  10. i:  Programming  Levels 


High-Level  Language 

A  program  may  be  written  in  a  high-level  language  such  as  BASIC, 
APL,  PASCAL,  or  others.  Techniques  for  programming  in  these  vari- 
ous languages  are  covered  by  specific  books  and  will  not  be  reviewed 
here.  We  will,  therefore,  only  briefly  review  this  mode  of  program- 
ming, A  high-level  language  offers  powerful  instructions  which  make 
programming  much  easier  and  faster.  These  instructions  must  then  be 
translated  by  a  complex  program  into  the  final  binary  representation 
that  a  microcomputer  can  execute.  Typically,  each  high-level  instruc- 
tion will  be  translated  into  a  large  number  of  individual  binary  instruc- 
tions. The  program  which  performs  this  automatic  translation  is  called 
a  compiler  or  an  interpreter.  A  compiler  will  translate  all  the  instruc- 
tions of  a  program  in  sequence  into  object  code.  In  a  separate  phase, 
the  resulting  code  will  then  be  executed.  By  contrast,  an  interpreter  will 
interpret  a  single  instruction,  then  execute  it,  then  "translate"  the  next 
one,  then  execute  it.  An  interpreter  offers  the  advantage  of  interactive 
response,  but  results  m  low  efficiency  compared  to  a  compiler.  These 
topics  will  not  be  studied  further  here.  Let  us  revert  to  the  programming 
of  an  actual  microprocessor  in  the  assembly-level  language. 
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SOFTWARE  SUPPORT 

We  will  review  here  the  main  software  facilities  which  are  (or  should 
be)  available  in  the  complete  system  for  convenient  software  develop- 
ment. Some  of  the  definitions  have  already  been  introduced.  They  will 
be  summarized  here  and  the  rest  of  the  important  programs  will  be  de- 
fined before  we  proceed. 

The  assembler  is  the  program  which  translates  the  mnemonic  repre- 
sentation of  instructions  into  their  binary  equivalent,  ll  normally  trans- 
lates one  symbolic  instruction  into  one  binary  instruction  (which  may 
occupy  1,  2  or  3  bytes).  The  resulting  binary  code  \s  called  objeci  code. 
It  IS  directly  executable  by  the  microcomputer.  As  a  side  effect,  the 
assembler  will  also  produce  a  complete  symbolic  lisimg  of  the  program, 
as  well  as  the  equivalence  tables  to  be  used  by  the  programmer  and  the 
symbol  occurrence  list  in  the  program.  Examples  will  be  presented  later 
m  this  chapter. 

In  addition,  the  assembler  will  list  syntax  errors  such  as  instructions 
misspelled  or  illegal,  branching  errors,  duplicate  labels  or  missing 
labels. 

It  will  not  delete  logical  errors  (this  is  your  problem). 

A  compiler  is  the  program  which  translates  high-level  language  in- 
structions into  their  binary  form. 

An  mlerpreter  is  a  program  similar  to  a  compiler,  which  also  trans- 
lates high-level  instructions  mto  their  binary  form  but  does  not  keep  the 
intermediate  representation  and  executes  them  immediately.  In  facl,  it 
often  does  not  even  generate  any  intermediate  code,  but  rather  executes 
the  high-level  instructions  directly, 

A  momlor  is  the  basic  program  which  is  indispensable  for  using  the 
hardware  resources  of  this  system.  It  continuously  monitors  the  input 
devices  for  input  and  manages  the  rest  of  the  devices.  As  an  example,  a 
minimal  monitor  for  a  single-board  microcomputer,  equipped  with  a 
keyboard  and  with  LED's,  must  continuously  scan  the  keyboard  for  a 
user  input  and  display  the  specified  contents  on  the  iight-emitting 
diodes,  in  addition,  it  must  be  capable  of  understanding  a  number  of 
limited  commands  from  the  keyboard,  such  as  START,  STOP,  CON- 
TINUE, LOAD  MEMORY,  EXAMINE  MEMORY.  On  a  large  sys- 
tem, the  monitor  is  often  qualified  as  the  execiiiive  program,  when 
complex  file  management  or  task  scheduling  is  also  provided.  The  over- 
all set  of  facilities  is  called  an  operating  system.  If  files  are  residing  on  a 
disk,  the  operating  system  is  qualified  as  the  disk  operating  svsiem,  or 
DOS. 
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An  editor  is  the  program  designed  to  facilitate  the  entry  and  the  mod- 
ification of  text  or  progams.  It  allows  the  user  to  enter  characters  con- 
veniently, append  them,  insert  them,  add  lines,  remove  lines,  search  for 
characters  or  strings.  It  is  an  important  resource  for  convenient  and  ef- 
fective text  entry. 

A  debugger  is  a  facility  necessary  for  debuggmg  programs.  When  a 
program  does  not  work  correctly,  there  may  typically  be  no  indication 
whatsoever  of  the  cause.  The  programmer,  therefore,  wishes  to  insert 
breakpoints  in  his  program  m  order  to  suspend  the  execution  of  the 
program  at  specified  addresses,  and  to  be  able  to  examine  the  contents 
of  registers  or  memory  at  this  point.  This  is  the  primary  function  of  a 
debugger.  The  debugger  allows  for  the  possibility  of  suspending  a  pro- 
gram, resummg  execution,  examining,  displaying  and  modifymg  the 
contents  of  registers  or  memory.  A  good  debugger  will  be  equipped 
with  a  number  of  additional  facilities,  such  as  the  ability  to  examine 
data  in  symbolic  form,  hex,  binary,  or  other  usual  representations,  as 
well  as  to  enter  data  in  this  format. 

A  loader,  or  linking  loader,  will  place  various  blocks  of  object  code 
at  specified  positions  in  the  memory  and  adjust  their  respective  sym- 
bolic pointers  so  that  they  can  reference  each  other.  It  is  used  to  relocate 
programs  or  blocks  in  various  memory  areas.  A  simulator  or  an  emu- 
lator program  is  used  to  simulate  the  operation  of  a  device,  usually  the 
microprocessor,  in  its  absence,  when  developing  a  program  on  a  simu- 
lated processor  prior  to  placing  it  on  the  actual  board.  Using  this  ap- 
proach, it  becomes  possible  to  suspend  the  program,  modify  it,  and 
keep  it  in  RAM  memory.  The  disadvantages  of  a  simulator  are  that: 

1 —  It  usually  simulates  only  the  processor  itself,  not  input/output 
devices 

2 —  The  execution  speed  is  slow,  and  one  operates  in  simulated  time. 
It  IS  therefore  not  possible  to  test  real-time  devices,  and  synchronization 
problems  may  still  occur  even  though  the  logic  of  the  program  may  be 
found  correct. 

An  emulator  is  essentially  a  simulator  m  real  time.  It  uses  one  proces- 
sor to  simulate  another  one,  and  simulates  it  in  complete  detail. 

Utility  routines  are  essentially  all  the  routines  which  are  necessary  m 
most  apphcations  and  that  the  user  wishes  the  manufacturer  had  pro- 
vided I 

They  may  include  multiplication,  division  and  other  arithmetic  oper- 
ations, block  move  routines,  character  tests,  input/output  device  han- 
dlers (or  "drivers"),  and  more. 
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THE  PROGRAM  DEVELOPMENT  SEQUENCE 

We  will  now  examine  a  typical  sequence  for  developing  an  assembly- 
level  program.  We  will  assume  that  all  the  usual  software  facilities  are 
available  m  order  to  demonstrate  their  value.  If  they  should  not  be 
available  in  a  particular  system,  it  will  still  be  possible  to  develop  pro- 
grams, but  the  convenience  will  be  decreased  and,  therefore,  the 
amount  of  lime  necessary  to  debug  the  program  is  likely  to  be  in- 
creased. 

The  normal  approach  is  to  first  design  an  algorithm  and  define  the 
data  structures  for  the  problem  to  be  solved.  Next,  a  comprehensive  set 
of  flowcharts  is  developed  which  represents  the  program  flow.  Finally, 
the  flowcharts  are  translated  into  the  assembly-level  language  for  the 
microprocessor;  this  is  the  coding  phase. 

Next,  the  program  has  to  be  entered  on  the  computer.  We  will  exam- 
ine in  the  next  section  the  hardware  options  to  be  used  in  this  phase. 

The  program  is  entered  in  RAM  memory  of  the  system  under  the 
control  of  the  editor.  Once  a  section  of  the  program,  such  as  one  or 
more  subroutines,  has  been  entered,  it  will  be  tested. 

First,  the  assembler  will  be  used.  If  the  assembler  did  not  already 
reside  in  the  system,  it  would  be  loaded  from  an  external  memory,  such 
as  a  disk.  Then,  the  program  will  be  assembled,  i.e.,  translated  into  a 
binary  code.  This  results  m  the  object  program,  ready  to  be  executed. 

One  does  not  normally  expect  a  program  to  work  correctly  the  first 
time.  To  verify  its  correct  operation,  a  number  of  breakpoints  will  nor- 
mally be  set  at  crucial  locations  where  it  is  easy  to  test  whether  the  inter- 
mediate results  are  correct.  The  debugger  will  be  used  for  this  purpose. 
Breakpoints  will  be  specified  at  selected  locations.  A  "Go"  command 
will  then  be  issued  so  that  program  execution  is  started.  The  program 
will  automatically  stop  at  each  of  the  specified  breakpoints.  The  pro- 
grammer can  then  verify,  by  examining  the  contents  of  the  registers,  or 
memory,  that  the  data  so  far  is  correct.  If  it  is  correct,  we  proceed  until 
the  next  breakpoint.  Whenever  we  find  incorrect  data,  an  error  in  the 
program  has  been  detected.  At  this  point,  the  programmer  normally 
refers  to  his  program  listing  and  verifies  whether  his  coding  has  been 
correct.  If  no  error  can  be  found  in  the  programming,  the  error  might 
be  a  logical  one  and  one  might  refer  to  the  flowchart.  We  wilt  assume 
here  that  the  flowcharts  have  been  checked  by  hand  and  are  assumed  to 
be  reasonably  correct.  The  error  is  likely  to  come  from  the  coding,  it 
will,  therefore,  be  necessary  to  modify  a  section  of  the  program.  If  the 
symbolic  representation  of  the  program  is  still  in  the  memory,  we  will 
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simply  re-enter  the  editor  and  modify  the  required  lines,  then  go 
through  the  preceding  sequence  again.  In  some  systems,  the  memory 
available  may  not  be  large  enough,  so  that  it  is  necessary  to  flush  out 
the  symbolic  representation  of  the  program  onto  a  disk  or  cassette  prior 
to  executmg  the  object  code.  Naturally,  in  such  a  case,  one  would  have 
to  reload  the  symbolic  representation  of  the  program  from  its  support 
medium  prior  to  entering  the  editor  agam. 

The  above  procedure  will  be  repeated  as  long  as  necessary  until  the 
results  of  the  program  are  correct.  Let  us  stress  that  prevention  is  much 
more  effective  than  cure.  A  correct  design  will  typically  result  in  a  pro- 
gram which  runs  correctly  very  soon  after  the  usual  typmg  mistakes  or 
obvious  coding  errors  have  been  removed.  However,  sloppy  design  may 
result  in  programs  which  will  take  an  extremely  long  time  to  be  de- 
bugged. The  debugging  time  is  generally  considered  lo  be  much  longer 
than  the  actual  design  time,  in  short,  it  is  always  worth  investmg  more 
time  m  the  design  in  order  to  shorten  the  debugging  phase. 

However,  using  this  approach,  it  is  possible  to  test  the  overall  organi- 
zation of  the  program,  but  not  to  lest  it  m  real  time  with  inpul/outpul 
devices.  If  input/output  devices  are  to  be  tested,  the  direct  solution  con- 
sists of  transferring  the  program  onto  EPROM's  and  installing  it  on  the 
board  and  then  watching  whether  it  works. 

There  is  a  better  solution.  It  is  the  use  of  an  itt-circmi  ennilator.  An 
in-circu!t  emulator  uses  the  Z80  microprocessor  {or  any  other  one)  to 
emulate  a  Z80  m  (almost)  real  time.  It  emulates  the  Z80  physically.  The 
emulator  is  equipped  with  a  cable  terminated  by  a  40-pin  connector,  ex- 
actly identical  to  the  pin-out  of  a  Z80,  This  connector  can  then  be  in- 
serted on  the  real  application  board  that  one  is  developing.  The  signals 
generated  by  the  emulator  will  be  exactly  those  of  the  Z80,  only  perhaps 
a  little  slower.  The  essential  advantage  is  that  the  program  under  test 
will  still  reside  in  the  RAM  memory  of  the  development  system,  U  will 
generate  the  real  signals  which  will  communicate  with  the  real  in- 
put/output devices  that  one  wishes  to  use.  As  a  result,  it  becomes  possi- 
ble to  keep  developing  the  program  using  all  the  resources  of  the  devel- 
opment system  (editor,  debugger,  symbolic  facilities,  file  system)  while 
testing  input/output  in  real  time. 

In  addition,  a  good  emulator  will  provide  special  facilities,  such  as  a 
trace.  A  trace  is  a  recording  of  the  last  instructions  or  status  of  various 
data  busses  in  the  system  prior  to  a  breakpoint.  In  short,  a  trace  pro- 
vides the  film  of  the  events  that  occurred  prior  to  the  breakpoint  or  the 
malfunction.  It  may  even  trigger  a  scope  at  a  specified  address  or  upon 
the  occurrence  of  a  specified  combination  of  bits.  Such  a  facility  is  of 
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great  value,  since  when  an  error  is  found  \l  is  usually  too  late.  The  in- 
struction,  or  the  data,  which  caused  the  error  has  occurred  prior  lo  the 
detection.  The  availabihty  of  a  trace  allows  the  user  to  find  which  seg- 
ment of  the  program  caused  ihe  error  lo  occur.  If  the  trace  is  not  long 
enough,  we  will  simpiy  set  an  earlier  breakpoint. 
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Fig,  10*2:  A  Typical  Memory  Map 


This  completes  our  description  of  ihe  usual  sequence  of  events  in- 
volved in  developing  a  program.  Let  us  now  review  the  hardware  alter- 
natives available  for  developing  programs. 
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HARDWARE  ALTERNATIVES 

Single-Board  Microcomputer 

The  single-board  microcomputer  offers  the  lowest  cost  approach  to 
program  development.  It  is  normally  equipped  with  a  hexadecimal  key- 
board, pitis  some  function  keys,  plus  6  LED's  which  can  display  ad- 
dress and  data.  Since  it  is  equipped  with  a  small  amount  of  memory,  an 
assembler  is  not  usually  available.  At  best,  it  has  a  small  monitor  and 
virtually  no  editing  or  debugging  facilities,  except  for  a  very  few  com- 
mands. All  programs  must,  therefore,  be  entered  in  hexadecimal  form. 
They  will  also  be  displayed  in  hexadecimal  form  on  the  LED's,  A  sin- 
gle-board microcomputer  has,  in  theory,  the  same  hardware  power  as 
any  other  computer.  Simply  because  of  its  restricted  memory  size  and 
keyboard,  it  does  not  support  ail  the  usual  facilities  of  a  larger  system 
and  makes  program  development  much  longer.  Because  it  is  tedious  to 
develop  programs  m  hexadecimal  format,  a  single  board  microcom- 
puter IS  best  suited  for  education  and  training  where  programs  of  lim- 
ited length  have  to  be  developed  and  their  short  length  is  not  an  obstacle 
to  programming.  Single-boards  are  probably  the  cheapest  way  to  learn 
programming  by  doing.  However,  they  cannot  be  used  for  complex 
program  development  unless  additional  memory  boards  are  attached 
and  the  usual  software  aids  are  made  available. 


The  Development  System 

A  development  system  is  a  microcomputer  system  equipped  with  a 
significant  amount  of  RAM  memory  (32K,  48K)  as  well  as  the  required 
input/output  devices,  such  as  a  CRT  display,  a  printer,  disks,  and,  usu- 
ally, a  PROM  programmer,  as  well  as,  perhaps,  an  in-circuit  emulator. 
A  development  system  is  specifically  designed  to  facilitate  program 
development  in  an  industrial  environment.  It  normally  offers  ail,  or 
most,  of  the  software  facilities  that  we  have  mentioned  in  the  preceding 
section.  In  principle,  it  is  the  ideal  software  development  tool. 

The  limitation  of  a  microcomputer  development  system  is  that  it  may 
not  be  capable  of  supporting  a  compiler  or  an  interpreter.  This  is  be- 
cause a  compiler  typically  requires  a  very  large  amount  of  memory, 
often  more  than  is  available  on  the  system.  However,  for  developing 
programs  in  assembly-level  language,  it  offers  all  the  required  facilities. 
But  because  development  systems  sell  in  relatively  small  numbers  com- 
pared to  hobby  computers,  their  cost  is  significantly  higher. 
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Hobby-Type  Microcomputers 

The  hobby-type  microcomputer  hardware  is  naturally  exactly  analo- 
gous to  that  of  a  development  system.  The  main  difference  lies  m  the 
fact  that  U  is  normally  not  equipped  with  the  sophisticated  software 
development  aids  which  are  available  on  an  mdustnal  development  sys- 
tem. As  an  example,  many  hobby-type  microcomputers  offer  only  ele- 
mentary assemblers,  mmimai  editors,  minimal  file  systems,  no  facilities 
to  attach  a  PROM  programmer,  no  in-circuit  emulator,  no  powerful 
debugger.  They  represent,  therefore,  an  intermediate  step  between  the 
stngle-board  microcomputer  and  the  full  microprocessor  development 
system.  For  a  user  who  wishes  lo  develop  programs  of  modest  complex- 
ity, they  are  probably  the  best  compromise,  since  they  offer  the  advan- 
tage of  low  cost  and  a  reasonable  array  of  software  development  tools, 
even  though  they  are  quite  limited  as  to  their  convenience. 

Time-Sharing  System 

It  !S  possible  to  rent  terminals  from  several  companies  which  will  con- 
nect to  time-shanng  networks.  These  terminals  share  the  lime  of  the 
larger  computer  and  benefit  from  all  the  advantages  of  large  installa- 
tions. Cross  assemblers  are  available  for  all  microcomputers  on  vir- 
tually all  commercial  time-sharing  systems.  A  cross  assembler  is  simply 
an  assembler  for,  say,  a  Z80  which  resides,  for  example,  in  an  1BM370. 
Formally,  a  cross  assembler  is  an  a.ssembler  for  microprocessor  X, 
which  resides  on  processor  Y.  The  nature  of  the  computer  being  used  is 
irrelevant.  The  user  still  writes  a  program  in  Z80  assembly-level  lan- 
guage, and  the  cross  assembler  translates  it  into  the  appropriate  binary 
pattern.  The  difference,  however,  is  that  the  program  cannot  be  ex- 
ecuted at  this  point.  It  can  be  executed  by  a  simulated  processor,  if  one 
is  available,  provided  u  does  not  use  any  mput/output  resources.  This 
solution  IS  used,  therefore,  only  in  industrial  environments, 

In-House  Computer 

Whenever  a  large  in-house  computer  is  available,  cross  assemblers 
may  also  be  available  to  facilitate  program  development,  if  such  a  com- 
puter offers  time-shared  service,  this  option  is  essentially  analogous  to 
the  one  above.  If  it  offers  only  batch  service,  this  is  probably  one  of  the 
most  inconvenient  methods  of  program  development,  since  submitting 
programs  in  batch  mode  at  the  assembly  level  for  a  microprocessor  re- 
sults in  a  very  long  development  time. 
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Front  Panel  or  No  Front  Panel? 

The  front  panel  is  a  hardware  accessory  often  used  to  facilitate  pro- 
gram debugging.  It  has  traditionally  been  a  tool  for  conveniently  dis- 
playing the  binary  contents  of  a  register  or  of  memory.  However,  al!  the 
functions  of  the  control  panel  may  be  accomplished  from  a  terminal, 
and  the  dominance  of  CRT  displays  now  offers  a  service  almost  equiva- 
lent to  the  control  panel  by  displaying  the  binary  value  of  bits.  The  ad- 
ditional advantage  of  usmg  the  CRT  display  is  that  one  can  switch  at 
will  from  binary  representation  to  hexadecimal,  to  symbolic,  to  decimal 
(if  the  appropriate  conversion  routines  are  available,  naturally).  The 
disadvantage  of  the  CRT  is  that  one  must  hii  several  keys  to  obtain  the 
appropriate  display  rather  than  turn  a  knob.  However,  since  the  cost  of 
providing  a  control  panel  is  quite  substantial,  most  recent  microcom- 
puters have  abandoned  this  debuggmg  tool.  The  value  of  the  control 
panel  is  often  considered  more  on  the  basis  of  emotional  arguments  in- 
fluenced by  one's  own  past  experience  than  by  the  use  of  reason.  It  is 
not  indispensable. 

Summary  of  Hardware  Resources 

Three  broad  cases  may  be  distinguished.  If  you  have  only  a  minimal 
budget  and  if  you  wish  to  learn  how  to  program,  buy  a  ssngle-board 
microcomputer.  Using  it,  you  will  be  able  to  develop  all  the  simple  pro- 
grams in  this  book  and  many  more.  Eventually,  however,  when  you 
want  to  develop  programs  of  more  than  a  few  hundred  instructions, 
you  will  feel  the  limitations  of  this  approach. 

If  you  are  an  industrial  user,  you  will  need  a  full  development  system. 
Any  solution  short  of  the  full  development  system  will  cause  a  signifi- 
cantly longer  development  time.  The  trade-off  is  clear:  hardware  re- 
sources vs.  programming  time.  Naturally,  if  the  programs  to  be  devel- 
oped are  quite  simple,  a  less  expensive  approach  may  be  used.  How- 
ever, if  complex  programs  are  to  be  developed,  u  is  difficult  to  justify 
any  hardware  savings  when  buying  a  development  system,  since  the 
programming  costs  will  be  by  far  the  dominant  cost  of  the  project. 

For  a  personal  computerist,  a  hobby-type  microcomputer  will  typi- 
cally offer  sufficient,  although  minimal,  facilities.  Good  development 
software  is  still  to  come  for  many  of  the  hobby  computers.  The  user  will 
have  to  evaluate  his  system  in  view  of  the  comments  presented  in  this 
chapter. 

Let  us  now  analyze  in  more  detail  the  most  indispensable  resource: 
the  assembler. 
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THE  ASSEMBLER 

We  have  used  assembly-level  language  throughouc  this  book  withoul 
presenting  the  formal  syntax  or  definition  of  assembly-level  language. 
The  time  has  come  to  present  this  dellnition.  An  assembler  is  designed 
to  allow  the  convenient  symbolic  representation  of  the  user  program, 
and  yet  to  make  it  simple  for  the  assembler  program  to  convert  these 
mnemonics  into  their  binary  representation. 


Assembier  Fields 

When  typing  in  a  program  for  the  assembler,  we  have  seen  that  fields 
are  used.  They  are: 

The  label  field,  optional,  which  may  contain  a  symbolic  address  for 
the  instruction  that  follows. 

T/ie  (nsiruction  field,  which  includes  the  opcode  and  any  operands. 
(A  separate  operand  field  may  be  distinguished.) 

The  comnieiii  field,  far  to  the  right,  which  is  optional  and  is  intended 
to  clarify  the  program. 

These  fields  are  shown  on  the  programming  form  in  Figure  10.3, 

Once  the  program  has  been  fed  to  the  a.ssembler,  the  a.ssembler  will 
produce  a  listing  of  it.  When  generaimg  a  listing,  the  as.sembler  will 
provide  three  additional  fields,  usually  on  the  left  of  the  page.  An  ex- 
ample appears  on  Figure  10.4.  On  the  far  left  is  the  line  number.  Each 
h'ne  which  has  been  typed  by  the  programmer  is  assigned  a  symbolic  line 
number. 

The  ne.xt  field  to  the  right  is  the  actual  address  field,  which  shows  in 
hexadecimal  the  value  of  the  program  counter  which  wiM  point  to  that 
instruction. 

Moving  still  further  to  the  right,  we  find  the  he.xadecimal  representa- 
tion of  the  instruction. 

This  shows  one  of  the  possibie  uses  of  an  assembler.  Even  if  we  are 
designing  programs  for  a  single-board  microcomputer  which  accepts 
only  hexadecimal,  we  should  sliil  wnie  the  program  in  assembly-level 
language,  providing  we  have  access  to  a  system  equipped  with  an  a.s- 
sembler. We  can  then  run  the  programs  on  the  .system,  using  the  a.ssem- 
bler. The  assembler  will  automatically  generate  the  correct  he.xadecimal 
codes  on  our  system.  This  shows,  in  a  simple  example,  the  value  of  ad- 
ditional software  resources. 
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SYMBOLIC 
OPCODE 

LABEL 
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to 

z  ■■■ 

ADDRcSa 

Fig.  10,3:  Microprocessor  Programming  Form 
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Tables 

When  the  assembler  translates  the  symbolic  program  into  its  binary 
representation,  it  performs  two  essential  tasks: 

1 —  It  translates  the  mnemonic  instructions  into  their  binary  en- 
coding. 

2 —  It  translates  the  symbols  used  for  constants  and  addresses  into 
their  binary  representation. 

In  order  to  facilitate  program  debugging,  the  assembler  shows  at  the 
end  of  the  listing  the  equivalence  between  the  symbol  used  and  its  hexa- 
decimal value.  This  is  called  the  symbol  table. 

Some  symbol  tables  will  not  only  list  the  symbol  and  its  value,  but 
also  the  line  numbers  where  the  symbol  occurs,  thereby  providing  an 
additional  facility. 

Error  IVIessages 

During  the  assembly  process,  the  assembler  will  detect  syntax  errors 
and  include  them  as  part  of  the  final  listing.  Typical  diagnostics  in- 
clude: undefined  symbols,  label  already  defined,  illegal  opcode,  illegal 
address,  illegal  addressing  mode.  Many  more  detailed  diagnostics  are 
naturally  desirable  and  are  usually  provided.  They  vary  with  each  as- 
sembler. 

The  Assembly  Language 

Opcodes  have  already  been  defined.  We  will  here  define  the  symbols, 
constants  and  operators  which  may  be  used  as  part  of  the  assembler 
syntax. 

Symbols 

Symbols  are  used  to  represent  numerical  values,  either  data  or  ad- 
dresses. Symbols  may  include  up  to  six  characters,  and  must  start  with 
an  alphabetical  character.  The  characters  are  restricted  to  letters  of  the 
alphabet  and  numbers.  Also,  the  user  may  not  choose  names  identical 
to  the  opcodes  utilized  by  the  Z80,  the  names  of  registers  such  as  A,B, 
C.D,E,H,L,  BC,  DE,  HL.  AF,  BC,  DE,  IX,  lY,  SP.  as  well  as  the 
various  short  names  used  as  pseudo-operators  by  the  assembler.  The 
names  of  these  assembler  "directives"  are  listed  below  m  the  corre- 
sponding sections.  Also,  the  abbreviations  used  to  designate  the  flags 
should  not  be  used  as  symbols:  C,Z,N,PE.NC,P.PO,NZ,M. 
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Assigning  a  Value  to  a  Symbol 

Labels  are  special  symbols  whose  values  do  not  need  to  be  defined  by 
the  programmer.  The  value  will  automatically  be  defined  by  the  assem- 
bler program  whenever  it  finds  that  label.  The  label  value  thus  auto- 
matically corresponds  to  the  address  of  the  instruction  generated  at  the 
line  where  it  appears.  Special  pseudo-instructions  are  available  to  force 
a  new  starting  value  for  labels,  or  to  assign  them  a  specific  value. 


flOO  J 
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O !  O.S 

oil  1 

0 1  I  :i 

01  li 
01  iH 
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ij  iioft  Mt!i  f  I.  I^  ji  HJf o  t 
ill  ir:  HIT  riiMfnt!-- 

;      T    f=£.';Ml  :    !  M  '> 
;  SSfTI  I    MF  I!  lEff  i 

;  L=n'.'L  I'l  J  i.i  F( 

-us !  1-i     fH  --.uii  !  rniunr  I 

::r!1!!-:l.   ^j.'ISH.  ! 


0 


Fig*  10.4:  Assembler  Output — An  Example 
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However,  other  symbols  used  for  constants  or  memory  addresses 
must  be  defined  by  the  programmer  prior  to  their  use. 

A  special  assembler  directive  may  be  used  to  assign  a  value  to  any 
symbol.  A  directive  is  essentially  an  instruction  to  the  assembler  which 
will  not  be  translated  into  an  executable  statement.  For  example,  the 
constant  LOG  will  be  defined  as: 

LOG    DFW  3002H 

This  assigns  the  value  3002  hexadecimal  to  the  variable  LOG.  The 
assembler  directives  will  be  examined  in  detail  in  a  later  section. 

Constants  or  Literals 

Constants  may  traditionally  be  expressed  either  In  decimal,  m  hexa- 
decimal, in  octal,  or  in  binary,  or  as  alphanumeric  strings.  In  order  to 
differentiate  between  the  base  used  to  represent  the  number,  a  symbol 
must  be  used.  To  load  "0"  into  the  accumulator,  we  will  simply  write: 

LD    A,  0 

Optionally  a  "D"  may  be  used  at  .the  end  of  the  constant. 

A  hexadecimal  number  will  be  terminated  by  the  symbol  "H",  To 
load  the  value  "FF"  into  the  accumulator,  we  will  write: 

LD    A,  OFFH 

An  octal  symbol  is  terminated  by  the  symbol  "0"  or  "Q".  A  binary 
symbol  is  terminated  by  "B"= 

For  example,  in  order  to  load  the  value  "  1 1 1 1 1 1 11 "  into  the  accumu- 
lator, we  will  write: 

LD    A,  lUlUlIB 

Literal  ASCII  characters  may  also  be  used  m  the  literal  field.  The 
ASCII  symbol  must  be  enclosed  in  single  quotes. 

For  example,  in  order  to  load  the  symbol  "S"  into  the  accumulator, 
we  will  write: 

LD   A,  'S' 

Exercise  10. 1:  Will  the  following  two  instructions  load  the  same  value 
in  the  accumulator:  LD  A.  '5',  and  LD  A,  SH? 
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Note  that  in  the  Ziiog  convention,  parentheses  denote  an  address. 
For  example: 

LD    A,  {10) 

specifies  that  the  accumuiator  is  loaded  from  the  contents  of  memory 
location  10  (decimal). 

Operators 

In  order  Eo  further  facilitate  the  writing  of  symbolic  programs,  as- 
semblers allow  the  use  of  operators.  At  a  minimum,  they  should  allow 
plus  and  minus  so  that  one  can  specify,  for  example: 

LD    A.  (ADDRESS) 
LD    A,  (ADDRESS  +1) 

U  IS  important  to  understand  that  the  expression  ADDRESS  +  I  will 
be  computed  by  the  assembler  in  order  to  determme  the  actual  memory 
address  which  must  be  inserted  as  the  binary  equivalent.  It  will  be  com- 
puted at  assembly  turn,  not  at  program-execution  time. 

In  addition,  more  operators  may  be  available,  such  as  multiply  and 
divide,  a  convenience  when  accessing  tables  in  memory.  More  special- 
ized operators  may  be  also  available,  such  as  greater  than  and  less 
than,  which  truncate  a  two-byte  value  respectively  mio  us  high  and  low 
byte. 

Naturally,  an  expression  must  evaluate  to  a  positive  value.  Negative 
numbers  may  normally  not  be  used  and  should  be  expressed  in  a  hexa- 
decimal format. 

Finally,  a  special  symbol  is  traditionally  used  to  represent  the  current 
value  of  the  address  of  the  Hne:  "S".  This  symbol  should  be  interpreted 
as  "current  location"  (value  of  PC). 

Exercise  10,2:  What  is  the  difference  between  the  following  instruc- 
tions? 

LD    A,  lOiOlOlOB 
LD    A,  (lOlOlOlOB) 

Exercise  10.3:  What  is  the  effect  of  the  following  instruction? 

JR    NC.  S  -  2 

Expressions 

The  Z80  assembler  specifications  allow  a  wide  range  of  expressions 
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with  arithmetic  and  logical  operations.  The  assembler  will  evaluate  the 
expressions  in  a  left-to-right  manner,  using  the  priorities  specified  by 
the  table  m  Figure  10,5.  Parentheses  may  be  usedto  enforce  a  specific 
order  of  evaluation.  However,  the  outermost  parentheses  will  denote 
that  the  contents  are  to  be  treated  as  an  address. 

Assembler  Directives 

Directives  are  special  orders  given  by  the  programmer  to  the  assem- 
bler, which  result  either  in  storing  values  into  symbols  or  into  the  mem- 
ory, or  in  controlling  the  execution  or  printing  modes  of  the  assembler. 
The  set  of  commands  which  specifically  controls  the  printing  modes  of 
the  assembler  is  also  called  "commands"  and  is  described  tn  a  separate 
section. 

To  provide  a  specific  example,  let  us  review  here  the  1 1  assembler 
directives  available  on  the  Zilog  development  system: 

ORG  nn 

This  directive  will  set  the  assembler  address  counter  to  the  value  nn.  In 
other  words,  the  first  executable  instruction  encountered  after  this 
directive  will  reside  at  the  value  nn.  It  can  be  used  to  locate  different 
segments  of  a  program  at  different  memory  locations. 

EQU  nn 

This  directive  is  used  to  assign  a  value  to  a  label. 
DEFL  nn 

This  directive  also  assigns  a  value  nn  to  a  label,  but  may  be  repeated 
within  the  program  with  different  values  for  the  same  label,  whereas 
EQU  may  be  used  only  once. 

DEFB  'S' 

This  directive  assigns  eight-bit  contents  to  a  byte  residing  at  the  current 
reference  counter. 

DEFB  'S' 

assigns  the  ASCII  value  of  "S"  to  the  byte. 
DEFW  nn 

This  assigns  the  value  nn  to  the  two-byte  word  residing  at  the  current 
reference  counter  and  the  following  location. 
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OPERATOR 

FUNCTION 

PRIORITY 

+ 

UNARY  PLUS 

1 

UNARY  MINUS 

1 

.NOT.  or  \ 

LOGICAL  NOT 

1 

.RES. 

RESULT 

1 

EXPONENTIATiON 

2 

* 

MULTIPLICATION 

n 

/ 

DlVISyON 

3 

.MOD. 

MODULO 

3 

.SHR. 

LOGICAL  SHIFT  RIGHT 

3 

.SHL. 

LOGICAL  SHIFT  LEFT 

3 

+ 

ADDITION 

4 

SUBTRACTION 

4 

.AND,  or  a 

LOGICAL  AND 

5 

.OR.  or  1 

LOGICAL  OR 

6 

.XOR. 

LOGICAL  XOR 

6 

.EQ.  or  = 

EQUALS 

7 

.GT.  or  > 

GREATER  THAN 

7 

.LT.  or  < 

LESS  THAN 

7 

.UGT. 

UNSIGNED  GREATER  THAN 

7 

.ULT. 

UNSIGNED  LESS  THAN 

7 

Fig.  10.5:  Operator  Precedence 

DEFS  nn 

reserves  a  block  of  memory  size  nn  bytes,  starting  at  the  current  value 
of  the  reference  counter. 


DEFM  'S' 

stores  into  memory  Lhe  stnng  'S'  starting  at  the  current  reference  coun- 
ter. U  must  be  less  than  63  in  length. 

MACRO  PO  Pl.-.Pn 

is  used  to  define  a  label  as  a  macro,  and  to  define  its  formal  parameter 
list.  Macros  are  defined  in  another  section  below. 

END 

indicates  the  end  of  the  program.  Any  other  statements  foUovt'ing  it  will 
be  ignored. 

ENDM 

is  used  to  mark  the  end  of  a  macro  definition. 
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Assembler  Commands 

Commands  are  used  to  modify  the  format  of  the  listing  to  control  the 
printing  modes  of  the  assembler.  All  commands  start  with  a  star  in  col- 
umn one.  Seven  commands  are  provided  by  the  Z80  assembler.  Typical 
examples  are: 

EJECT 

which  causes  the  listing  to  move  to  the  top  of  the  next  page;  and 
LIST  OFF 

which  causes  the  pnntmg  to  be  suspended,  effective  with  this  com- 
mand. The  others  are:  "*HEADINGS",  "*LISTON",  "*MACLIST 
ON",  "*MACLIST  OFF",  "*INCLUDE  FILENAME". 

Macros 

A  macro  is  simply  a  name  assigned  to  a  group  of  instructions.  It  is  a 
convenience  to  the  programmer.  If  a  group  of  instructions  is  used  sev- 
eral times  m  a  program,  we  could  define  a  macro  to  represent  them,  in- 
stead of  always  having  to  write  this  group  of  mstructions. 

As  an  example,  we  could  write: 

SAVREG  MACRO 
PUSH  AF 
PUSH  BC 
PUSH  DE 
PUSH  HL 
ENDM 

then  simply  write  the  name  "SAVREG"  instead  of  the  above  instruc- 
tions. Any  time  that  we  write  SAVREG,  the  five  corresponding  lines 
will  get  substituted  instead  of  the  name.  An  assembler  equipped  with  a 
macro  facility  is  called  a  macro-assembler.  When  the  macro  assembler 
encounters  a  SAVREG,  it  performs  a  mere  physical  substitution  of 
equivalent  lines. 

Macro  or  Subroutine? 

At  this  point,  a  macro  may  seem  to  operate  in  a  way  analogous  to  a 
subroutine.  This  is  not  the  case.  When  the  assembler  is  used  to  produce 
the  object  code,  any  time  that  a  macro  name  is  encountered,  it  will  be 
replaced  by  the  actual  instructions  that  it  stands  for.  At  execution  time, 
the  group  of  instructions  will  appear  as  many  times  as  the  name  of  the 
macro  did. 
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By  contrast,  a  subroutine  is  defined  only  once,  and  tlien  it  can  be 
used  repeatedly;  the  program  will  jump  to  the  subroutine  address.  A 
macro  is  called  an  assembly-time  facility.  A  subroutine  is  an  execiition- 
iime  facility.  Their  operation  is  quite  different. 

Macro  Parameters 

Each  macro  may  be  equipped  with  a  number  of  parameters.  As  an 
example,  let  us  consider  the  followmg  macro: 


This  macro  will  result  m  swapping  (exchanging)  the  contents  of  mem- 
ory locations  M  and  N.  A  swap  between  two  registers,  or  two  memory 
locations,  is  an  operation  which  is  not  provided  by  the  Z80.  A  macro 
may  be  used  to  implement  it.  "T"  in  this  instance  is  simply  the  name 
for  a  temporary  storage  location  required  by  the  program.  As  an  exam- 
ple, let  us  swap  the  contents  of  memory  locations  ALPHA  and  BETA. 
The  instruction  which  does  this  appears  below: 

SWAP  (ALPHA),  (BETA),  (TEMP) 

In  this  instruction,  TEMP  is  the  name  of  some  temporary  storage 
location,  which  we  know  to  be  available  and  which  can  be  used  by  the 
macro.  The  resulting  expansion  of  the  macro  appears  below: 

LD    A,  (ALPHA) 
LD    (TEMP),  A 
LD    A,  (BETA) 
LD    (ALPHA),  A 
LD    A,  (TEMP) 
LD    (BETA),  A 

The  value  of  a  macro  should  now  be  apparent:  it  is  convenient  for  the 
programmer  to  use  pseudo-instructions,  which  have  been  defined  with 
macros.  In  this  way,  the  apparent  instruction  set  of  the  Z80  can  be  ex- 
panded at  will.  Unfortunately,  one  must  bear  in  mind  that  each  macro 


SWAP  MACRO 


LD 
LD 
LD 
LD 
LD 
END 


A,  m 
#r,  A 
A,  m 

#M,  A 

A,  /rc 
m,  A 

M 


;  M  INTO  A 

;  A  INTO  T  (  =  M) 

;  N  INTO  A 

;  A  INTO  M  {  =  N) 

;  T  INTO  A 

;  A  INTO  N  (  =  T) 
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directsve  will  expand  into  whatever  number  of  instructtons  were  used.  A 
macro  will,  therefore,  run  more  slowly  than  any  smgie  instruction.  Be- 
cause of  its  convenience  for  the  development  of  any  long  program,  a 
macro  facility  is  highly  desirable  for  such  applications. 

Additional  Macro  Facilities 

Many  other  directives  and  syntactic  facilities  may  be  added  to  a  sim- 
ple macro  facility;  macros  may  be  nested,  i.e.,  a  macro  call  may  appear 
within  a  macro  definition.  Using  this  facility,  a  macro  may  modify  it- 
self with  a  nested  definition!  A  first  call  will  produce  one  expansion, 
whereas  subsequent  calls  will  produce  a  modified  expansion  of  the  same 
macro.  This  is  allowed  by  the  Z80  assembler,  but  nested  definitions  are 
not  allowed. 


CONDITIONAL  ASSEMBLY 

Conditional  assembly  is  another  facility  provided  in  the  Z80  assem- 
bly. With  a  conditional  assembly  facility,  the  programmer  can  devise 
programs  for  a  variety  of  cases,  and  then  conditionally  assemble  the 
segments  of  codes  required  by  a  specific  application.  As  an  example,  an 
industrial  user  might  design  programs  to  take  care  of  any  number  of 
traffic  lights  at  an  intersection,  for  a  variety  of  control  algorithms.  He 
will  then  receive  the  specifications  from  the  local  traffic  engineer,  who 
specifies  how  many  traffic  lights  there  should  be  and  which  algorithms 
should  be  used.  The  programmer  will  then  simply  set  parameters  in  his 
program  and  assemble  conditionally.  The  conditional  assembly  will 
result  in  a  "customized"  program  which  will  retain  only  those  routines 
which  are  necessary  for  the  solution  to  the  problem. 

Conditional  assembly  is,  therefore,  of  specific  value  to  industrial 
program  generation  in  an  environment  where  many  options  exist  and 
where  the  programmer  wishes  to  assemble  portions  of  programs  quick- 
ly and  automatically  in  response  to  externa!  parameters. 

Only  two  conditional  pseudo-CPs  are  provided  in  the  standard 
micro-assembler  version  supplied  by  Zilog,  They  are  respectively: 

COND  NN  and  ENDC 

where  NN  represents  an  expression.  The  pseudo-OP  "COND  NN"  will 
result  in  the  evaluation  of  the  expression  NN.  As  long  as  the  expression 
evaluates  to  a  true  value  (non-zeroj,  the  statement  following  the  COND 
will  be  assembled.  However,  if  the  expression  should  be  false,  i.e.,  eval- 


600 


PROGRAM  DEVELOPMENT 


uale  to  a  zero  value,  the  assembly  of  all  subsequent  statements  will  be 
disabled  up  to  ihe  ENDC  mstruciion. 

ENDC  Ks  used  to  terminate  a  COND,  so  that  the  assembly  of  subse- 
quent siatemenLs  ss  re-enab!ed.  The  COND  pseudo-OP's  cannot  be 
nested. 

In  theory,  inore  powerful  condiuonal  assembly  facilities  could  exist, 
wuh  "IF"  and  "ELSE"  specificaiion.  They  may  become  available  in 
future  versions  of  the  assembler. 

SUMMARY 

This  chapter  has  presented  the  techniques  and  the  hardware  and  soft- 
ware tools  required  to  develop  a  program,  along  with  the  various  trade- 
offs and  alternatives. 

These  range  at  the  hardware  level  from  the  single-board  microcom- 
puter to  the  full  development  system;  at  the  software  level,  from  binary 
coding  to  high-level  programming. 

You  will  have  to  .select  them  on  the  basis  of  your  goals  and  resources. 
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CHAPTER  11 

CONCLUSION 


We  have  now  covered  all  important  aspects  of  programming,  from 
definitions  and  basic  concepts  to  the  internal  manipulation  of  the  Z80 
registers,  to  the  management  of  input/output  devices,  as  well  as  the 
characteristics  of  software  development  aids.  What  is  the  next  step? 
Two  views  can  be  offered,  the  first  one  relating  to  the  development  of 
technology,  the  second  one  relating  to  the  development  of  your  own 
knowledge  and  skill.  Let  us  address  these  two  points. 

TECHNOLOGICAL  DEVELOPMENT 

The  progress  of  integration  in  MOS  technology  makes  it  possible  to 
implement  more  and  more  complex  chips.  The  cost  of  implementing  the 
processor  function  itself  is  constantly  decreasing.  The  result  is  that 
many  of  the  input/output  chips  or  the  peripheral-controller  chips  used 
in  a  system  now  incorporate  a  simple  processor.  This  means  that  most 
LSI  chips  in  the  system  are  becoming  programmable.  An  interesting 
conceptual  dilemma  is  now  developing.  In  order  to  simplify  the  soft- 
ware design  task,  as  well  as  to  reduce  the  component  count,  the  new 
I/O  chips  now  incorporate  sophisticated  programmable  capabilities: 
many  programmed  algorithms  are  now  integrated  within  the  chip. 
However,  as  a  result,  the  development  of  programs  is  complicated  by 
the  fact  that  all  these  input/output  chips  are  radically  different  and 
need  to  be  studied  in  detail  by  the  programmer!  Programming  the 
system  is  no  longer  programmmg  the  microprocessor  alone,  but  also 
programnung  all  the  other  chips  attached  to  it.  The  learning  time  for 
every  chip  can  be  significant. 

Naturally,  this  is  only  an  apparent  dilemma.  If  these  chips  were  not 
available,  the  complexity  of  the  interface  to  be  realized,  as  well  as  of  the 
corresponding  programs,  would  be  still  greater.  The  new  complexity 
that  is  introduced  is  the  need  to  program  more  than  just  a  processor. 
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andtoiearn  the  various  features  of  the  different  chips  in  a  system.  How- 
ever, it  is  hoped  that  the  techniques  and  concepts  presented  in  this  book 
will  make  this  a  reasonably  easy  task. 

THE  NEXT  STEP 

You  have  now  learned  the  basic  techniques  required  to  program  sim- 
ple appUcations  on  paper.  That  was  the  goal  of  this  book.  The  next  step 
is  actual  practice  for  which  there  is  no  substitute.  It  is  impossible  to  learn 
programming  completely  on  paper;  experience  is  required.  You  should 
now  be  in  a  position  to  start  writing  your  own  programs.  It  is  hoped 
that  this  journey  will  be  a  pleasant  one. 
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28 

29 
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B4 

as 

86 

67 
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95 
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C 
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3072 

49152 

D 
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S10 
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0 
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0 
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6 
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7 

B 
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8 
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8 

8 

P 
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9 
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9 
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9 
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9 
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10,485,760 

A 

655,360 

A 
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A 
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A 
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B 
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B 

It 
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C 
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C 
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C 

3,072 

C 
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C 

12 

D 

13.631,488 

D 
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D 
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D 
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D 

208 

D 

13 

E 
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E 
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E 
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E 
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E 
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14 
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ASCII  CONVERSION  TABLE 


HEX 

MSD 

0 

1 

2 

3 

4 

5 

6 

7 

LSD 

BITS 

000 

001 

010 

Oil 

100 

101 

110 

111 

0 

0000 

NUL 

OLE 

SPACE 

0 

@ 

P 

- 

P 

1 

0001 

SOH 

DC1 

! 

1 

A 

Q 

a 

q 

2 

0010 

STX 

DC2 

2 

B 

R 

b 

r 

3 

0011 

ETX 

DC3 

# 

3 

C 

S 

c 

s 

4 

0100 

EOT 

DC4 

S 

4 

D 

T 

d 

1 

5 

0101 

ENQ 

NAK 

% 

5 

E 

U 

e 

u 

6 

0110 

ACK 

SYN 
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6 

F 

V 

( 

V 

7 

0111 

BEL 

ETB 

^ 

7 

G 

w 

9 

w 

8 

1000 

BS 
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( 

8 

H 

X 

h 

X 

9 
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HT 

EM 

) 

9 

1 

Y 

j 

y 

A 
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LF 
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J 

Z 

1 

2 

8 
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VT 
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+ 
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[ 

k 

{ 

C 

1100 

FF 

FS 

< 

L 

\ 

! 

D 
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CR 

GS 

M 

] 

m 

T 

E 

1110 

SO 

RS 

> 

N 

A 

n 

F 

1111 

SI 

US 

9 

O 

■e— 

0 

DEL 

THE  ASCII  SYMBOLS 


NUL 

-Nuil 

OLE 

—Data  Link  Escape 

SOH 

"Star!  o!  Headfiig 

DC 

—Device  Control 

STX 

-Star!  otText 

NAK 

-Negative  Acknowledge 

ETX 

—End  of  Text 

SVN 

— Svnchronous  Idie 

EOT 

—End  of  Tranamisslon 

ETB 

—End  of  Transmission  Block 

ESQ 

—Enquiry 

CAN 

-Cancel 

ACK 

—Acknowledge 

EM 

—End  o!  Medium 

BEL 

-Sell 

sue 

-Substitute 

BS 

—Backspace 

ESC 

—Escape 

HT 

—  Horliontal  Tabulatkjn 

FS 

-Hie  Separator 

LF 

-Line  Feed 

GS 

—Group  Separator 

VT 

—Vertical  Tebufatlon 

RS 

-Record  Separator 

FF 

— Fonn  Feed 

US 

-Unit  Separator 

CR 

—Carriage  Helum 

SP 

—Space  (Blank) 

SO 

-Siiitt  Out 

□EL 

— DeielB 

$1 

-Shift  in 
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RELATIVE  BRANCH  TABLES 


FORWARD  RELATIVE  BRANCH  TABLE 
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BACKWARD  RELATIVE  BRANCH  TABLE 
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DECIMAL  TO  BCD  CONVERSION 
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BCD 

DEC 

BCD 

DEC 

BCD 

0 

0000 
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10010000 
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00010001 
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0010 
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00010010 
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8 
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IB 

0001 1000 

98 

1001 1000 

9 
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19 

00011001 

99 

10011001 
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Z80  INSTRUCTION  CODES 

(The  literal  d  is  shown  as  05  in  the  objecs  code,  t 


OBJ 

SOURCE 

CODE 

STATEMEMT 

BE 

ADC 

A,(HL) 

003  EOS 

ADC 

A.(!X+d! 

FD8E05 

ADC 

A.IIY+di 

BF 

ADC 

A.A 

88 

ADC 

A.B 

89 
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AOC 

A.D 
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A,H 
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A.L 
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HL.BC 
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HL.DE 

EDBA 

ADC 

HL.HL 
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ADC 
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A.B 
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S3 
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ADD 
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ADD 
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03 

ADD 

HL.BC 

19 

ADO 

HL.OE 

29 

ADO 

HL.HL 

39 

ADD 

HL.SP 

0009 

ADO 

IX, BC 

DD19 

ADD 

IX.DE 

DD29 

ADD 

IX. IX 

0039 

ADD 

IX.SP 

FD09 

ADD 

lY.BC 

FD19 

ADD 

lY.DE 

FD29 

ADD 

iYJY 

FD39 

ADD 

lY.SP 

A6 

AND 

IHLI 
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A4 
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OBJ 

SOURCE 

CODE 

STAT 

EMENT 

£620 

AWO 

CB46 

SIT 

Q.(HL) 

DDCB0546 

SIT 

G,(  IX+dJ 

FDCB0546 

HIT 

□  1  i 

O.ilV+d} 

CB47- 

BIT 

O.A 

CB40 

BJT 

O.S 

CB41 

BIT 

O.C 

CB42 

BIT 

0  .0 

CB43 

BIT 

0  .E 

CB44 

BIT 

0  .H 

CB45 

BIT 

O.L 

CB4£ 

BIT 

1  {HLt 

DDCB054E 

BIT 

FDCB054E 

BIT 

1.U  Y+d/ 

CB4F 

BIT 

)  ,A 

CB48 

BIT 

1  ,B 

CB49 

BIT 

1  ,c 

C84A 

SIT 

t.D 

C84B 

BIT 

1,E 

CB4C 

BIT 

1  ,H 

CB4D 

BIT 

I.L 

CSS6 

BIT 

2.IHLI 

BIT 

2,UX+d} 

BIT 

2,{tY+d) 

CB57 

BIT 

3. A 

CB50 

BIT 

2,8 

CB51 

BIT 

2  C 

CB52 

B  IT 

2  D 

CB53 

BIT 

2  £ 

CB54 

BIT 

2  H 

CB55 

BIT 

2.L 

CB5E 

BIT 

3.1HL1 

DOCB055E 

BIT 

3,!IX+d) 

FDCB055E 

BIT 

3  (lY^-d) 

CBSF 

BIT 

3,A 

CB58 

BIT 

3,8 

CB59 

BIT 

3.C 

CB5A 

BIT 

3,D 

CBEB 

SIT 

3,E 

CB5C 

BIT 

3,H 

CBBD 

BIT 

3.L 

CB66 

BIT 

4.iHLI 

DDCB0566 

SIT 

4,(1  X+dl 

FDCB0S66 

BIT 

4,(1  Y+d) 

CB57 

B!T 

4,A 

ceeo 

BIT 

4,B 

CB61 

BIT 

4,C 

CBS2 

BIT 

4.D 
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CODE  STATEMENT 


CB63 

BIT 

4,E 

CB64 

BIT 

4,H 

CBS5 

BIT 

4,L 

casE 

BIT 

S.iHL) 

ODCB056E 

8!T 

5.(IX+d) 

FDCBOBGE 

BIT 

5,!IY+d) 

CB6F 

BOT 

5,A 

CB68 

BIT 

5,B 

C86B 

BIT 

5,C 

C86A 

BIT 

5,D 

CB6B 

BIT 

5,E 

CB6C 

BIT 

S.H 

CB60 

BIT 

S.L 

CB76 

BIT 

6.(HL) 

DDCa0576 

BIT 

6,llX+d) 

FOCB0576 

BIT 

5,{!Y+d) 

CB77 

BiT 

6.A 

ca70 

BIT 

6,8 

CB7! 

aiT 

6,C 

CB72 

BIT 

6,D 

CB73 

BiT 

6.6 

CB7<! 

BIT 

6.H 

CB75 

BIT 

S.L 

CB7E 

SIT 

7.IHLI 

DDCB0S7E 

BIT 

7.!IX+dl 

FOCS057E 

BIT 

7.(IYtdl 

CB7F 

SiT 

7,  A 

CB7S 

BIT 

7. a 

CB79 

BIT 

7,C 

CB7A 

SIT 

7.D 

CB7B 

BIT 

7,e 

CB7C 

BIT 

7,H 

Ca7D 

BIT 

7,L 

DCB'SDS 

CALL 

C.nn 

CALL 

M,nn 

0^8405 

CALL 

NC.nn 

018405 

CALL 

NZ.nn 

F4S405 

CALL 

P.iin 

ECB405 

CALL 

PE.nn 

E4B405 

CALL 

PO.nn 

CC840S 

CALL 

Z.nn 

CD8405 

CALL 

ni? 

3F 

CCF 

BE 

CP 

(HLI 

DO  BEOS 

CP 

nxtdS 

FDBEOS 

CP 

IIY*dS 

BF 

CP 

A 

BB 

CP 

B9 

CP 

c 

BA 

CP 

D 

BB 

CP 

E 

BC 

CP 

H 

BD 

CP 

L 

FE20 

CP 

EDAg 

cpo 

E0B9 

CPoa 

OBJ  SOURCE 


CODE 

STATEMENT 

CPIR 

CUM  i 

CPl 

2F 

CPL 

27 

OAA 

35 

iu  1  1 
i  n  L ) 

OD3505 

DEC 

llX+tfl 

FD350S 

DEC 

(lY+d^ 

3D 

OEC 

05 

DEC 

Q 

OB 

DEC 

BC 

OD 

DEC 

c 

15 

DEC 

D 

IB 

OEC 

OE 

10 

DEC 

E 

DEC 

H 

28 

DEC 

HL 

0D2B 

OgC 

iX 

FD2B 

OEC 

lY 

20 

oec 

L 

3B 

OEC 

SP 

r.3 

01 

DJWZ 

I.' 

FB 

El 

£3 

EX 

ISPKHL 

D0E3 

EX 

ISPKIX 

FD63 

EX 

ISPI.IY 

OS 

EX 

AF.AF' 

EB 

ex 

DE,HL 

□9 

6XX 

76 

HALT 

ED46 

ihA 

0 

ED56 

IM 

r 

EDSe 

IM 

2 

ED7a 

m 

A.ICI 

BOW 

IM 

S.ICI 

E048 

IN 

C.iCI 

£050 

IN 

D,(C) 

EDS8 

IN 

E.iC) 

EO60 

IN 

H,IC) 

eD6S 

IN 

L.iC) 

34 

INC 

IHL! 

OD3405 

INC 

llX+di 

F 03405 

INC 

!IY+ril 

3C 

!NC 

A 

04 

INC 

8 

03 

SNC 

BC 

DC 

INC 

c 

54 

INC 

Q 

13 

INC 

DE 

1 C 

INC 

E 

34 

INC 

H 

23 

INC 

HL 

0023 

INC 

IX 

F023 

INC 

1  Y 

2C 

INC 

L 

33 

twc 

SP 

0620 

IN 

A.fnl 
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OBJ  SOURCE 
CODE  STATEMENT 


EDAA 

IND 

EDBA 

man 

EDA2 

m\ 

EDB3 

INIR 

C3840S 

JP 

E9 

Jp 

IHL! 

Doeg 

JP 

(iXI 

F0E9 

JP 

UYi 

DA8<)05 

Jp 

Cnn 

FA3405 

JP 

Mnn 

D2B40S 

JP 

MC.nn 

C2B4Q5 

JP 

NZnn 

F284aS 

JP 

P,nn 

EA8405 

JP 

PE.nit 

E2B405 

JP 

PO.nn 

CA84a5 

JP 

382  E 

JB 

C.f 

302  E 

JB 

fiC.f 

202  E 

JR 

N2.U 

2B2E 

JB 

Z.B 

182E 

JR 

,,  ML 

02 

LD 

itiO.A 

)2 

LO 

iDEI.A 

77 

LO 

!HL!.A 

70 

LD 

(HLi.B 

71 

LD 

(HLl.C 

72 

LD 

IHLI.D 

73 

LO 

(HLi.E 

74 

LO 

(HLi.H 

7S 

LD 

IHLl.L 

3620 

LU 

(HLS.n 

D077Q5 

LD 

!IX+d),A 

DO700S 

to 

!IX+d).B 

OD7105 

LD 

l!X+dl.C 

OD7205 

LD 

llX+d),D 

DD730S 

LD 

{1X+dS,£ 

D07405 

LD 

IIX+d),H 

DD7605 

LD 

ilX  +  dl.L 

00360520 

LD 

!!X+d),n 

FD770S 

LD 

((Yfd),A 

f=D7005 

LD 

(IV+d!.B 

fO7l05 

LD 

(IY+d|,C 

FD7205 

LD 

IIV+dS,D 

F  07305 

LD 

t(V+dl,E 

FD7405 

LD 

FD7S05 

LD 

irv+di.L 

FD360520 

LD 

328405 

LD 

lonKA 

£0438405 

LO 

(nni.BC 

£0538405 

LO 

Innl.DE 

22B405 

LD 

(nnj.HL 

00228405 

LO 

lltrtl.lX 

FD22840S 

LO 

(nnlJV 

£0738405 

LD 

irSRi.SP 

OA 

LD 

A.(8C) 

1A 

LO 

A.IDEl 

7E 

LD 

A,(HLS 

OBJ  SOURCE 
CODE  STATEMENT 


0  07  EOS 

LO 

A,l1X+d) 

FD7E05 

LO 

A,{lY+d) 

3A8405 

LD 

A.Inn) 

7F 

LO 

A,A 

78 

LD 

A,B 

79 

LO 

A,C 

7A 

LD 

A,0 

7B 

LO 

A.E 

7C 

LD 

AH 

ED57 

LD 

AJ 

70 

LD 

A,L 

3620 

LD 

A,n 

ED5F 

LD 

A.R 

4B 

LO 

B,1HL) 

DD4605 

LD 

B.(IX+d) 

F 04605 

LD 

B,(lY+dl 

47 

LO 

B.A 

40 

LD 

B,B 

41 

LD 

B,C 

42 

LD 

8,0 

43 

lD 

8.E 

44 

LO 

a.H 

45 

LD 

B.L 

0620 

LD 

B.n 

ED4B8405 

LO 

ec.lnnl 

018405 

LO 

BCnn 

4E 

LO 

CIHL) 

DD4Ea5 

LD 

C,UX+df 

FD4E05 

LO 

C.I!Y+dl 

4F 

LO 

C.A 

48 

LD 

C.B 

49 

LO 

C.C 

4A 

LO 

C,0 

4B 

LD 

C.E 

40 

LD 

C.H 

40 

LD 

C.L 

0E20 

LO 

C.n 

56 

LD 

O.lHLl 

005605 

LD 

0,!lX+dl 

FDseas 

LD 

D.l?¥+d! 

57 

LO 

0,A 

SO 

LD 

D,B 

51 

LO 

O.C 

52 

LD 

0.0 

53 

LD 

0,E 

54 

LD 

D,H 

55 

LO 

D.L 

1620 

LD 

D,n 

EOSBB405 

LD 

OE.Innl 

118405 

LD 

DE.nn 

SE 

LD 

e,!HLl 

OD5E05 

LD 

E.ifX+dl 

F05E05 

LD 

£.(IY+di 

5F 

LD 

E,A 

58 

LD 

E.B 

59 

LO 

£.C 

5A 

LD 

E.D 
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OBJ  SOURCE 
CODE  STATEMENT 


5B 

LD 

E.E 

5C 

LD 

E,H 

SD 

LD 

E,L 

1 E20 

LD 

E,n 

66 

LD 

H  ( H  L  ^ 

OD6605 

LO 

H,OX+dl 

FD6605 

LD 

H  {1  Y  +  dl 

67 

LO 

H.A 

60 

LD 

H  B 

6t 

LO 

Hie 

62 

LO 

R,0 

63 

LD 

M.E 

64 

LO 

H.H 

65 

LD 

H.L 

2620 

LD 

H.ts 

2A840S 

LD 

Hl,!t!nl 

21S40S 

LO 

HL,nn 

£047 

LO 

l,A 

DD3AS405 

LD 

iX.Cnnj 

00218405 

LO 

IX,nn 

FD3AS<105 

LO 

lYJnni 

FD2 18405 

LD 

lY.rSR 

BE 

LD 

L.IHLi 

DD6E05 

LD 

L.(IX+dl 

LD 

L.IIY*dj 

6F 

LO 

L.A 

6B 

LD 

L,B 

69 

LD 

L.C 

6A 

LD 

L.D 

6B 

LD 

L,E 

6C 

LD 

L.H 

6D 

LD 

L,L 

3E20 

LD 

L,n 

E04F 

LO 

fl.A 

ED7Ba405 

LO 

SP,(nn) 

F9 

LD 

SP.HL 

DDF9 

LD 

Sf  JX 

FDF9 

LD 

SP.IY 

318405 

LD 

SP.nn 

EDAS 

LOD 

EDBe 

LOOR 

EDAO 

LDI 

EOBO 

LOIR 

ED44 

NEG 

00 

NOP 

B6 

OH 

(HLi 

ODB605 

OR 

(IX4d) 

FD8605 

OR 

!PV+dl 

B7 

OR 

A 

SO 

OR 

B 

SI 

OR 

C 

82 

OR 

D 

83 

OR 

E 

64 

OR 

H 

B5 

OR 

L 

F620 

OR 

n 

ED8B 

OTDR 

OBJ  SOURCE 


CODE 

STATEMENT 

EDB3 

OTiR 

ED79 

OUT 

(C)  A 

ED41 

OUT 

{C}  B 

ED49 

OUT 

(C)  c 

ED5T 

OUT 

iC}  0 

ED53 

OUT 

!C1  E 

£051 

OUT 

fCl  H 

ED63 

OUT 

iC)  L 

D320 

OUT 

(r^KA 

£DAB 

EDA3 

QUTI 

F1 

AF 

CI 

POP 

BC 

01 

DE 

Ei 

POP 

H  L 

DDE! 

FOP 

1 X 

FDE1 

POP 

F5 

PUSH 

AF 

C5 

PUSH 

8C 

OB 

PUSH 

OE 

£5 

PUSH 

HL 

DDE5 

PUSH 

IX 

FOES 

?USH 

1 Y 

CB86 

RES 

O.iHL) 

DDCB05B6 

RES 

0,{IX+d) 

FDCB0586 

RES 

O.IIY+d! 

CB87 

RES 

0,A 

CBBO 

HES 

O.B 

CB81 

RES 

o.c 

CB82 

RES 

Q.D 

CB83 

RES 

0,E 

CBB4 

RES 

O.H 

caes 

RES 

O.L 

CB8E 

RES 

i.lHLI 

DDCBOSSE 

RES 

l.ilX^dl 

FDCB058E 

SES 

1,(IY+d] 

CB8F 

RES 

l,A 

CB8S 

RES 

(.B 

CBSS 

RES 

I.C 

caSA 

RES 

1,0 

case 

RES 

i.E 

CBSC 

RES 

l,H 

CBSO 

RES 

i,L 

CB96 

RES 

2,IHL1 

DDCB0SB6 

RES 

2.(1  X+dl 

FDCS0SS6 

RES 

2.IIY*dl 

CB97 

RES 

2.A 

CB90 

RES 

2.B 

cagi 

RES 

2.C 

CB92 

RES 

2.0 

CB93 

RES 

2,E 

CB94 

RES 

2.H 

CBgs 

RES 

2,L 

CB9E 

RES 

3.IHLI 

ODCB059E 

RES 

3,(IX+d! 

FDCE059E 

RES 

3.{IY+dl 
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OBJ  SOURCE 
CODE  STATEMENT 


CB9F 

RES 

3,A 

CB98 

RES 

3.B 

CB99 

RES 

3,C 

CBSA 

RES 

3,0 

CB9B 

RES 

3,E 

CB9C 

RES 

3.H 

CB9D 

RES 

3,L 

CBA6 

RES 

4,{HL) 

OOCB05AB 

RES 

4,(1  X+dl 

FDCB05A6 

RES 

4,(IY+d( 

CBA7 

RES 

4,A 

CBAO 

HES 

4,B 

CBA1 

RES 

4,C 

CBA2 

RES 

1.D 

CBA3 

RES 

<!,£ 

CBA4 

RES 

4,H 

CBA5 

RES 

4,L 

C8AE 

RES 

S.IHL) 

DDCB05A6 

RES 

5,(1  X+dl 

FDCB05AE 

RES 

5,{IY+c() 

CBAF 

RES 

S,A 

CBA8 

RES 

5,8 

CBA9 

RES 

5,C 

CBAA 

RES 

5,D 

CBAB 

RES 

5.e 

CBAC 

RES 

5,H 

CBAP 

SES 

5,L 

CBB6 

RES 

6.IHLI 

DDC805S6 

nes 

6.IIX+d} 

FocBosae 

RES 

5.(1  Y+d) 

CBB7 

RES 

6,A 

CBBO 

RES 

B,B 

CBB1 

RES 

B.C 

CBB2 

RES 

5,0 

CBB3 

RES 

6,E 

CBBH 

RES 

6,H 

CBB5 

RES 

6.L 

CBBE 

RES 

7,(HL! 

DDCBQ5BE 

RES 

7.!IX+d) 

FDCBOSBE 

RES 

7.IIV*d} 

CBBF 

RES 

7,  A 

CBB8 

RES 

7,8 

CBBS 

RES 

7,C 

CBBA 

RES 

7,0 

CBBB 

RES 

7,E 

CBBC 

RES 

7,H 

CBBD 

RES 

7,L 

C9 

RET 

08 

RET 

C 

F8 

RET 

M 

DO 

HET 

NC 

CO 

RET 

m 

FO 

RET 

P 

EB 

RET 

PE 

EO 

RET 

PO 

ca 

RET 

z 

OBJ  SOURCE 
CODE  STATEMENT 


ED4D 

RETI 

ED45 

RETN 

CB16 

SL 

IHLl 

DDCB0516 

RL 

!IX+d! 

FDCB0516 

HL 

llY-f-di 

CS^7 

H}. 

A 

CB10 

RL 

B 

CB11 

RL 

C 

CB12 

RL 

D 

CB13 

RL 

£ 

CB14 

RL 

H 

CB15 

RL 

L 

17 

RLA 

CB06 

RLC 

(hl: 

DDCB0505 

RLC 

(IX+di 

FDCB0SO6 

RLC 

ilY+dl 

CB07 

RLC 

A 

CBOO 

RLC 

B 

CB01 

RLC 

C 

CB02 

RLC 

D 

CB03 

RLC 

E 

CB04 

RLC 

H 

CBOS 

RLC 

L 

07 

RLC  A 

ED6F 

RLD 

CBIE 

RR 

(HL) 

OOCBOBIE 

RR 

(IX+dl 

Foceosi  E 

RR 

(IY*d! 

CBIF 

RR 

A 

CB1B 

RR 

e 

CB19 

RR 

c 

CBl  A 

RR 

0 

CB1B 

RR 

E 

CBl  C 

RR 

H 

C81D 

RR 

L 

1F 

RRA 

CBoe 

RRC 

(HLI 

{IX+d} 

RRC 

CBOF 

RRC 

CBOB 

RRC 

B 

CB09 

RRC 

CSOA 

RRC 

Q 

CBOB 

RRC 

£ 

CBOC 

RRC 

H 

CBOD 

RRC 

L 

OF 

RRCA 

ED67 

RRD 

C7 

RST 

00  H 

CF 

RST 

OBH 

07 

RST 

10H 

QF 

BST 

IBH 

E7 

RST 

20H 

EF 

RST 

2BH 

F7 

RST 

30H 

FF 

RST 

38  H 

□  630 

SBC 

A,n 
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OBJ  SOURCE 
CODE  STATEMENT 


9S 

SBC 

A. (ML) 

DD9E05 

SBC 

A,(IX+dl 

FD9E05 

SBC 

A.llY+d! 

9F 

SBC 

A.A 

98 

SBC 

A.B 

99 

SBC 

A.C 

9A 

SBC 

A,D 

9B 

SBC 

A.e 

9C 

SBC 

A.H 

9D 

SBC 

A.L 

ED42 

sec 

HL.BC 

ED52 

sec 

HL.DE 

ED62 

SBC 

HL.HL 

ED72 

SBC 

HL.SP 

37 

SCF 

cacs 

SET 

Q.(HL) 

OOCB0SC6 

SET 

O.IIX*df 

FDC805C6 

SET 

0,(1  Y+d) 

CBC7 

SET 

0,A 

CBCO 

SET 

O.B 

caci 

SET 

0,C 

C8C2 

SET 

O.D 

CBC3 

SET 

O.E 

CBC4 

SET 

0,H 

CBCS 

SET 

O.L 

CBCE 

SET 

i.lHLI 

DDCB05CE 

SET 

i,(IX+d) 

FDCB05CE 

SET 

^{lY+d) 

CBCF 

SET 

i.A 

CBC8 

SET 

I.B 

cac9 

SET 

I.C 

CBCA 

SET 

1,0 

CBCB 

SET 

l.£ 

CBCC 

SET 

1  ,H 

CBCD 

SET 

I.L 

CBD6 

SET 

2.fHL) 

DDCB05D6 

SET 

FDCB05O6 

SET 

2.ilYtdl 

CBD7 

SET 

2,A 

CBDO 

SET 

2,S 

CB01 

SET 

2.C 

CB02 

SET 

2.D 

CBD3 

SET 

2,£ 

SET 

2.H 

CBD5 

SET 

2.L 

CBDS 

SET 

3.B 

CBDE 

SET 

3.fHU 

DOCBOSDE 

SET 

3.(IX-tdl 

FOCBOSOe 

SET 

3,(lY+dl 

CBDF 

SET 

3, A 

CBD9 

SET 

3,C 

CBDA 

SET 

3.D 

caoB 

SET 

3,E 

CBDC 

SET 

3.H 

CBDD 

SET 

3.L 

CBE5 

SET 

OBJ  SOURCE 
CODE  STATEMENT 


DDcaoses 

SET 

4.(IX+d) 

FDCB05EB 

SET 

4.1IY*dS 

caE7 

SET 

4.A 

caEo 

SET 

4.B 

CBE! 

SET 

4.C 

CBe2 

SET 

4,0 

CBE3 

SET 

4.E 

CBE4 

SET 

4.H 

CBES 

SET 

4,L 

CBEE 

SET 

5.IHL1 

□DCB05EE 

SET 

FDC805EE 

SET 

5,{IY+dl 

CBEF 

SET 

5. A 

CBE8 

SET 

s,e 

caeg 

SET 

S.C 

C8EA 

SET 

5.0 

CSEB 

SET 

5.E 

CBEC 

SET 

5,H 

CBED 

SET 

5,L 

CBF6 

SET 

6,iHL) 

DDCB05F6 

SET 

6,(!X+di 

FDCB05F6 

SET 

6,(iY+d! 

CBF? 

SET 

S.A 

CBFO 

SET 

6.B 

CBFl 

SET 

G.C 

CBF3 

SET 

6.0 

CBFS 

SET 

6,E 

CBFl 

SET 

6.H 

CBF5 

SET 

6,L 

CBFE 

SET 

7,(HL) 

ODCBOSFE 

SET 

7,(IX+dj 

FDCB05FE 

SET 

7,(iY+d) 

CBFF 

SET 

7.A 

CBF8 

SET 

7.B 

CBF9 

S£T 

7.C 

CBFA 

SET 

7,D 

CBFS 

SET 

"'.E 

CBFC 

SET 

7.H 

CBFO 

SET 

7.L 

ca26 

SLA 

(HLJ 

DOCB0526 

SLA 

!IX+dl 

FDCB0S26 

SLA 

IIY+dl 

CB27 

SLA 

A 

CB20 

SLA 

6 

CB21 

SLA 

C 

CB22 

SLA 

0 

CB23 

SLA 

E 

Ca2't 

SLA 

H 

CB25 

SLA 

L 

CB2E 

SRA 

(HL) 

OOCB052E 

SRA 

(IX+d! 

FDCBQ52E 

SRA 

!IY+d) 

CB2F 

SRA 

A 

CB2B 

SRA 

B 

C829 

SRA 

C 

CB2A 

SRA 

D 
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OBJ 

SOURCE 

CODE 

STATEMENT 

CS3B 

SRA 

E 

CB2C 

SRA 

H 

SRA 

L 

CB3£ 

SRL 

IHL! 

SRL 

llXtdl 

SRL 

flY*d) 

CB3F 

SRL 

A 

CB38 

SRL 

B 

CB39 

SRL 

c 

CB3A 

SBL 

D 

CB3B 

SRL 

E 

CB3C 

SRL 

H 

CB3D 

SBL 

L 

96 

SUB 

IHLI 

SUB 

ax*di 

SUB 

llV  +  di 

n7 
y ' 

SUB 

A 

3D 

SUB 

B 

9 1 

SUB 

C 

92 

SUB 

D 

93 

SUB 

E 

9-4 

SUB 

H 

95 

SUB 

L 

D620 

SUB 

n 

AE 

XOfl 

(HLi 

w  l.^       L^U  J 

xoa 

ilX*dl 

T  LJ 

XOR 

(lY+d) 

AF 

XOR 

A 

A8 

XOR 

B 

A9 

XOR 

C 

AA 

XOR 

D 

AB 

XOR 

E 

AC 

XOR 

H 

AD 

XOR 

L 

EE2Q 

XOR 

n 

(Coiiriesy  ofZilo<t  Inc. ) 
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Z80  to  8080  EQUIVALENCE 


oQaU 

Ton 

808Cj 

ZBQ 

8080 

ADC  A,  (HL) 

ADCM 

EX  (SP),  HL 

XTHL 

OR  rt 

ORl  iB2 1 

Anr  A  n 

HALT 

HLT 

OR  r 

ORA  f 

A,  |n  1 

iN  iB2i 

OH  jHL} 

ADD  A  (HI) 

ADD  M 

ENC  BC 

iNX  B 

1  fn ),  " 

ADD  A  n 

Am  iT^')\ 

JNC  OE 

ADD  A 

ADD  r 

INC  HI 

POPBC 

POP  a 

0AD8 

POPDE 

POPO 

rtuu  ML.  Ut 

iNC  SP 

INX  5P 

POP  HL 

POP  H 

Annul  ui 

DADH 

PUSH  AE 

PUSH  PSW 

ADD  HL  5P 

DAD  SP 

i(-  tan  trkll 

PUSH  BC 

PUSHB 

ANDn 

AN!  (B3| 

JP  M,  nn 

JM  |B2]|B3i 

PUSH  OE 

PUSHO 

AND  f 

ANA  J 

JP  NC,  nn 

JNC  183)  [B31 

PUSH  HI 

PUSH  H 

ANDlHt) 

ANAM 

JP  nn 

JMP  IB21  |B3i 

RET 

RET 

CALL  C.  nn 

CC1B2]  |B31 

JPNZ,  nn 

JNZSB2J  [331 

RETC 

ftC 

CAILM.  no 

CM  (BI]  |B3] 

JP  P,  nn 

JPIB2I  [B3! 

PETM 

RM 

CALl  NC,  nn 

CNC  [B2j  jB31 

JP  PE,  nn 

JPE  iB2][a3l 

RETNC 

RNC 

CAU  nn 

CAU 

JP  PO,  on 

jPO  [821(831 

RETNZ 

RNZ 

CALLN:.  nn 

CNZ(82)  fB3j 

JPZ.  nn 

iZ  1621  [B3] 

SETP 

HP 

CAU  P  nn 

CPjB2J|B3l 

jP(Ht) 

PCHl 

SETPE 

RFE 

CAtt  K.  nn 

CPE  IB!) [B31 

LDA,  (OEi 

IDAX 

REf  PO 

RPO 

CALl  PO,  nn 

CFO  I33|  (B3) 

LOA,  (nn) 

IDA  fB2[  (B3) 

RETZ 

StZ 

CAtLZ,  nn 

CZ  iB21JB3] 

[DDE,  nn 

LXID,  [B2]  |B3| 

SLA 

RAl 

CCf 

CMC 

tD  SP,  nn 

tXI  SP.  [32] [B3| 

SICA 

RIC 

CPf 

CMPf 

LD(BC),  A 

SrAXB 

SRA 

RAR 

cp(Hl; 

CMPM 

ID  (DE).  A 

STAX  D 

RSCA 

SRC 

CPl, 

CAAA 

l.D(HLS.  . 

MOVM.  . 

aSTP 

RSIP 

CPn 

CPtfB21 

LD  (nn),  A 

5TA  [B2]  (B3( 

SBC  A,  {HL| 

SBBM 

DAA 

DAA 

lD(nnj,  HL 

SHL01S21 1631 

SBC  A.  n 

SB!  [S21 

DECBC 

DCXB 

tDA.  (BCJ 

tDAXB 

SBC  A, , 

SBBr 

DECOE 

DCXD 

10  BC,  nn 

ixia,  ra2i[fl3i 

5CF 

STC 

DtCHL 

DCXH 

[DHL.  (nnj 

tHtD(B21[fi3i 

SUBn 

SU! [B21 

DEC. 

DCRf 

LOHL,  nn 

IXI  H  rB2J!B31 

SUBr 

SUBr 

DEC  5P 

OCXSP 

iDr.  ;hC) 

MOV  ) ,  M 

SUB{HL) 

SUBM 

DEC  IHLj 

DCRM 

ID  r,  r. 

MVI  t,  IB2! 

XORn 

xRi  rasi 

Dl 

Dt 

IDr.  ,' 

MOVrl,  r2 

XORr 

XRAt 

El 

£1 

LDSP,  HL 

SPHl 

XOR(HL) 

XRA  M 

EX  Oi,  HL 

XCHG 

NOP 

NOP 
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8080  to  Z80  EQUIVALENCE 


6080 

2.80 

8080 

Z80 

OvOv 

fan 

ACI  [621 

ADC  A  n 

IN  [B2| 

iN  A,  (n| 

POPH 

POPHL 

ADCM 

ADC  A,  {HL) 

!NRM 

!NC  (HI) 

POPPSW 

ADC. 

ADC  A,  . 

!WR  r 

INC . 

PUSH  8 

PUSH  ec 

ADDM 

ADD  A.  (HLj 

iNXB 

it-tC  BC 

PUSH  D 

PUSH-  DE 

ADD  r 

ADD  A.  1 

SNX  D 

IJ^C  DE 

PUSH  H 

PLJSH  HL 

ADI  IB21 

ADDA,  n 

^NX  H 

^NCHL 

PUSH  PSW 

PU5HAF 

ANANl 

AND(Hl,l 

SNXSP 

1NCSP 

RAl 

RLA 

ANAr 

ANDr 

JC  IB2| [B3} 

JPC.  nn 

RAR 

RBA 

ANirB2l 

AND  n 

JmSa5j|B3] 

JPM,  nn 

RC 

R£IC 

CAIL 

CAlLnn 

jmPIB2)[B31 

JPnn 

RET 

RET 

CC  [621  |B3I 

CALL  C.  nn 

JNC  IBS]  (63) 

JP  NC,  nn 

PLC 

RLCA 

CM|B21[B3| 

CAllM.  nn 

JN2  rB2Ha31 

JP  NZ,  nn 

RM 

RETM 

CMA 

CPL 

JP IB2J [331 

JP  P,  tin 

RNC 

RETNC 

CMC 

CCF 

JPESB21 [63] 

JPPE.  nn 

RNZ 

RETNZ 

Cmpm 

CPIHLI 

JPO  1321  [B31 

JP  PO.  nn 

RP 

REIP 

CMPr 

CPf 

JI  [B21  [B3i 

jPZ,  nn 

RP£ 

RETPE 

CNC  (85?  ;B35 

CALLNC.  nn 

lOA  fE2|  [B3t 

IDA,  (nn) 

RFO 

SEtFO 

CNZr82|(6Jl 

CALINZ.  nn 

LDAXB 

10  A.  (BC) 

ARC 

SRCA 

CP(B2j[B31 

CAll  P.  nn 

LDAXD 

IDA,  (DE) 

R5T 

HSTP 

CPS  rB2t |B3j 

CALL  PE,  nn 

IHlDrBJJ  |B31 

[DHL.  (nti) 

RZ 

RETZ 

CPI 1621 

CPn 

1X1  B  (B21  [aai 

LD  BC,  nn 

5B3M 

SBC  A.  (HI) 

CPO  [82]  [331 

CALL  PO.  nn 

iOlD  [B2t 

ID  DE,  nn 

SBBr 

SBC  A.  , 

CZ  r32J  iB3l 

CALL  I,  nn 

IXI  H  [B2]  [33] 

LD  HI.  nn 

SBI  IB21 

SBC  A,  n 

DAA 

OAA 

LXISP!B2i{B3 

LD  5P,  nn 

SHLO IB2!  [B31 

ID  (tin),  HL 

DADB 

ADD  HL,  8C 

MOVM, , 

LDiHL).  . 

SPHl 

LDSP.Hl 

!5ADD 

ADD  HL,  DE 

MOV  T,  M 

LD  r.  |HL) 

STA  fB2j  [831 

ID(nn),  A 

Dad  M 

ADD  HL.  HL 

MOV  r  1 ,  r2 

LD  r,  .  ' 

STAXB 

ID  (BC),  A 

DAD  5P 

ADD  HI.  SP 

MVjM 

LOiHL).  n 

5TAXD 

ID(D£),  A 

OCRM 

DEC  (HI) 

mV!  I  [B21 

LOf,  n 

STC 

SCF 

OCfif 

DEC, 

NOP 

NOP 

SUBM 

SUB  (HI) 

DCXB 

DECBC 

ORAM 

OK  (HI) 

SUBr 

SUBr 

oao 

DEC  DE 

OSAr 

OSr 

501(821 

im 

DCXH 

DCXSP 
Di 

DEC  Hi 
DtCSP 
DI 
6J 

HLT 

OffI  (Bit 

ourifl2| 

0»n 

OUT(n).  A 

XCHG 
XRAM 

EXDE.  Hi 
XORiHl] 

Ef 

PCHi 

JP{HL) 

XRAr 

XQRr 

HAir 

POP  a 

POPO 

POPBC 
POPDE 

XRi(621 
XTHL 

XOSn 
EX  (SPJ,  HL 
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B 

absolute  addressing 

108,439,446 

B 

62 

ACT 

61 

banks  of  registers 

62 

accumulaior 

439 

BASIC 

24 

ADC 

iOi 

basic  architecture 

46 

ADC.  A.  s 

190 

basse  concepts 

IS 

ADCHL,  ss 

192 

basic  programming  choices  579 

ADD 

101 

basse  programming  techniques  94 

ADD  A.(HL) 

84,  194 

BCD 

35,37,525 

ADDA,  {IX  +  d) 

196 

BCD  addition 

107.  no 

ADDA,  (lY  +  d) 

198 

BCD  arithmetic 

i07 

ADDA,  n 

67,200 

BCD  block  transfers 

530 

ADDA,  r 

67,75,76,201 

BCD  Oags 

112 

ADDHL,  ss 

203 

BCD  representation 

35 

ADD  IX,  rr 

205 

BCD  subtraction 

no 

ADDIY,  rr 

207 

BCD  table 

35 

addition 

58,95,  100,  105 

benchmark 

470 

address  bus 

47 

binary 

20,21,22,41,45 

address  registers 

51 

binary  code 

19 

addressing 

438,442 

binary  digit 

18 

addressing  modes    438,  440,  444,  445 

binary  division 

133 

addressing  techniques 

438 

binary  logic 

18 

algorithm 

15,  16,  1 14,539 

binary  representation 

41 

aiphabeuc  list         558,  565,  569,  570 

binary  search  546,558,559,560, 

alphanumeric  data 

39 

561,566,567,568 

ALU 

46,  77, 85 

BIT  b,  (HL) 

211 

AND 

!66,  167 

BIT  b,  (IX  +  d) 

213 

ANDs 

209 

BlTb,  (lY  +  d) 

2i5 

application  cxaitiples 

520 

BIT  b,  r 

217 

arithmetic-iogical  una 

46,61 

bit 

18,20,41 

arithmetic  programs 

94 

bit  addressing 

448 

arithmetic  shift 

119 

bit  manipulation 

172,  173 

Ascn 

39,  524.  525 

bit  serial  transfer 

471,472 

ASCII  conversion  table  40 

block 

540, 542, 544 

assembler 

96,  582, 590 

block  transfer  450,  451 ,  453. 458,  530 

assembler  directives 

596,  598 

block  transfer 

assembler  fields 

590 

instructions 

163.450,452 

assembly-language 

67,  580,  592 

bootstrap 

48 

assigning  a  value 

593 

bracket  testing 

523 

asynchronous 

471,496.  518 

branch  instruction 

441 

automated  Z80 

branching  point 

115 

instructions 

142,453,455 

break  character 

467 
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breakpoini 

584, 586 

bubbic-sort      533,  534,  535.  536,  537 

buffer  register 

59,61 

buffered 

49 

buffers 

61 

bus  request 

497 

BUSRQ 

92,  497 

byte 

18,  19,41,444 

C 

C  28.30,31,62.73 

CALL  145,156,446,500 

CALL  cc,  pq 

219 

CALL  pq 

222 

CCF 

224 

CALL  SUB 

143,  144,  145 

carry  22.23.26,28,30,174 

r"pn J l-nrnpocKinn  i,nil 

46 

checksum  computnLion 

544  545 

plTi^pt  nf  In'jlriif^t iritis 

154 

utaruiji  jiiL[iiury 

520 

clock 

47 

clock  cycles 

OV 

clock-synchronous  logic 

00 

code  conversion 

525 

coding 

lt3 

combinalion  chips 

48 

commands 

16 

commcni  field 

590 

compare 

53! 

compiler 

545,  581,582 

COND 

600 

conclusion 

602 

conditional  assembly 

600 

conditional  instruction 

50 

constants 

439,445,594 

control  box 

49 

control  bus 

47 

control  instructions 

157, 185 

control  registers 

512,513,515 

control  ssgnals 

91 

control  unit 

46 

count  ihe  zeroes 

529 

counter 

463,  465 

CP 

166 

CPs 

225 

CPD 

227 

CPDR 

229 

"yt  1 

CPIR 

233 

CP} 

CPU 

46,  187 

critical  race 

60 

44  587 

crystsl 

47 

cu 

46 

n 
u 

PlA  A 

rl^il n  hii ffpr 

51 1 

data  bus 

47 

data  counters 

51 

data  direciion  register 

512 

data  processing 

155 

data  processing  instructions  164 

daia  ready 

LLclLcl  i                ill u LtUll 

548 

J  J  ? 

data  transfers 

1  cj.  5  SR  1  fin 

i          i  Jo,  I OU 

debugger 

debugging 

IS 

decimai 

20,  2 1 1  22 

uck-  m 

Jin 

DEC  IX 

242 

DECIY 

243 

decode 

71,86 

decoding 

56 

decoding  logic 

49 

decrement 

164,  442 

DEFB 

596 

DEFL 

596 

DEFM 

597 

DEFS 

597 

DEFW 

596 

delay  generation 

463 

delay  loop 

464.  483 

deleting 

553.  565. 574 

design  examples 

548 

destination  register 

67 

development  systems 

587 

DFB 

596 

DI 

244 

direct  addressing 

439,441 

direct  binary 

19 

direction  register 

515 
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directives  146,571,580.594 

F 

directories 

541,545 

F 

61 

disk  operating  system 

541,582 

fesch 

55.  70,  84 

displacement 

63 

reich-exccuie  overlap 

78 

displaceiTscnt  field 

442 

FIFO 

543 

DJNZc 

245 

file  directory 

54! 

DMA 

491,498 

nags                   31,  50,  51,  179,  180 

documenling 

97 

nags  register 

61 

DOS 

582 

flip-flops 

51 

doubly-linked  lists 

545, 546 

floating  point  representatioi^     37,  38 

double-precision  formal 

34 

nowchariing 

16,  17,  114, 

drjvers 

49 

450,  464,  469,  494,  559 

G 

general  purpose  registers 

51 

E 

getting  characters  in 

522 

E 

62 

EBCDIC 

39 

H 

echo 

486 

H 

62,  176 

editor 

583 

half-carry  Oag(H) 

176 

EI 

247 

HALT 

92,  185,257 

8-bit  addition 

95 

handshaking 

477,478,511 

8-bit  division 

134, 137 

hardware 

93 

clement  deletion 

564 

hardware  delays 

465 

element  insertion 

550,  563 

hardware  organization 

46 

emulator 

583 

hardware  resources 

587, 589 

END 

597 

HEX 

525 

ENDC 

600 

hexadecimal 

41,42,481 

EN  DM 

597 

hexadecimal  coding 

43,  579 

EPROM's 

585 

high  byte 

103 

EQU 

596 

high  level  language 

58! 

error 

586 

error  messages 

592 

I 

EX  AF,  AFi 

162 

1 

63 

exchat)ge  snstruciions 

162 

iPFl 

499 

Exclusive  ORing 

31 

1FF2 

499 

EX  DE,  HL 

249 

illegal  code 

107 

executable  statements 

16 

IMO 

258 

execute 

71 

m  i 

259 

execution 

56, 69,  599 

mi 

260 

execution  cycle 

55 

immediate  addressing  108,159,439,445 

exponent 

37,  38 

immediate  operation 

69 

EXCSP),  HL 

250 

implicit  addressing 

438,  445 

EX(SP},  IX 

252 

implied  addressing 

438 

EX(SP),  lY 

254 

improved  multiplication 

126,  128,  129 

extended  addressing 

160,441,446 

SN  r,  (C) 

26! 

exiernai  representation 

IN  A,{N> 

263 

or  information 

41,44 

in-circuit  emulator 

585 

EXX 

256 

iNC(HL} 

267 
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!NCr                                   264                interrupltable  504 

mcremeni                         164,442                interrupt  vector  498 

mcremenier                            57               interrupts  495 

rNCrr                                    265                 i/O  control  92 

INC  (IX  +  d>                        268               iORQ  92, 500 

INC(JY  +  d)                            270                 IR  55 

INCIX                                 272                IX  53,63 

INCIY                                    273                 lY  63 
IND  274 
index  register             53,63,441,442  J 

indexed  addressing  160,441,447,540                JPcc,  pq  282 

indexing                                  63  JPnn  89 

indirect  addressing  443,444,448,540  JPpq  284 

indirect  indexed  addressing          443  JP(HL'l  285 

indirect  memory  access               499  JP(!X)  286 

INDR                                   276  jp(iY)  287 

information  representation             !8  JRcc,  e  288 

in-house  computer                     588  JRe  290 

INI  278  JUMP  90,172,179,44! 

!NIR                                    280  jumpsnstruction  156,182 

input/output  157,460,518  jump  relative  (JR>  446,447 
input/output  devices  511,521 

input/output  instructions       183, 460  K 

fnput  register  466  IK  24 
inserting                            552, 573 

instruction  96  L 

insiruclson  i'seld                       590  L  62 

instruction  formats                     66  label  field  590 

instruction  register                 55, 64  largest  element  526, 527 

instruction  set                          154  LDA,  (n,  ni  69,86 

instruction  types                       112  LDD,  C  72 

INT                                       91  LDD  164 

msernal  control  registers         51,513  LDDR  164 

internal  representation  LDl  164 

of  information                      18  LOIR  142,  164 

mferpreted                               69  LDdd,  (nn)  291 

interpreter                  545,581,582  LDdd.  nn  293 

interrupt        466,496,497,500,505,  LD  r,  n  295 

508,509,511  LDr,  r  66 

interrupt  acknowledge               500  LD  r,  r'  297 

interrupt  Hag                            187  LDCBC),  A  299 

interrupt  handler                     502  LD(DE),A  300 

interrupt  logic                           510  LD(HL),  n  301 

interrupl-mask-bil                      499  LD(HL),  r  303 

interrupt  mode  0                      500  LDr.(HLl  356 

interrupt  mode  1                      503  LD  r,  (!X  +  d)  305 

interrupt  mode 2                       504  LDr, (lY  +  d)  307 

interrupt  overhead                      504  LDflX  +  d),  n  309 

interrupt-page  addressmg  register    63  LD(IY  +  d),  n  3U 
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LD  (!X  +  d),  r 

313 

LD(IY  +  d),  r 

315 

LD  (nn),  A 

317 

LD(nn),  A 

319 

LD(nn),  dd 

321 

LD(nn),  HL 

323 

LD(nn),  tX 

325 

LD(nnJ,  !Y 

327 

LDA,  (BO 

329 

LD  A.{DE) 

330 

LDA,  I 

331 

LD  1,  A 

332 

LDA,  R 

333 

LDHL,  (nnt 

334 

LD  IX.  nn 

336 

LD  IX.Cnnt 

338 

LD  IY,(nn! 

340 

LD  lY,  nn 

342 

LD  R,  A 

344 

LDSP,  HL 

345 

LDSP,  [X 

346 

LDSP,  lY 

347 

LDD 

348 

LDDR 

350 

LDI 

352 

LDIR 

354 

LED 

41,480 

LIFO  slruclure 

540.  544 

light  emitting  diodes 

4! 

linked  list  542.544,568,571,573. 

574,577.  578 

linked  loader 

583 

list     540,  548,  549,  550,  555,  556, 557 

lissing 

590 

list  pointer 

542 

literal 

69,  439, 455, 594 

load 

96,  106 

loader 

583 

logarithmic  searching 

546, 562 

logical 

166,  558 

logical  errors 

582 

logical  operations 

HI 

logical  shift 

!19 

long  addressing 

449 

longer  delay 

464 

M 

machine  cycle  69 
MACRO  597, 598,  600 


INDEX 

mantissa 

38 

MASK 

168.522 

memorv  cycles 

55 

memory  map 

453, 586 

nietr5ory-nsapped  I/O 

!57 

memory-refresh  register 

64 

titicro  instructions 

86 

mnemonic 

67, 579 

MI 

92 

modes 

444 

monitor 

48,  582 

monitoring 

467 

MOS  Technology  6502 

452 

MPU 

52,  59 

MPU  pinout 

9t 

MREQ 

92 

multiple  devices 

506 

multiple  LED's 

482 

multiple  precision 

98 

multiplexer 

52, 62 

multiplication        U3,  114,  115.  1 16, 

124, 151,  152,  153 

MUX 

52,62 

N 

N 

34 

NEC 

358 

negative 

24,  26,  32 

nested  calls 

145 

nibble 

18.36 

NMi 

91,92,498 

nonmaskable  interrupt 

498 

nonrestormg  method 

133 

NOP 

359 

NOPs 

92 

normalize 

37 

normalized  mantissa 

37 

O 

octal 

41,42 

odometer 

465 

one's  complement 

25 

one-shot 

466 

opcode              66,  86, 439, 444, 446 

operand                100,  102,  438,439 

operating  system 

582 

operator  precedence 

587 

OR 

166,  168 

ORs 

360 
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,  r 
,  A 


ORG 
OTDR 
OT!R 
OUT  (C), 
OUT  (N), 
OUTD 
OUTI 

output  register 
overdraw 
overflow 
overlap  technique 


596 
362 
364 
366 
368 
369 
371 
461 
133 

28,30.31,32 
79 


packed  BCD  36,107 

packed  BCD  sublract  110.11! 

paper-tape  readers  494 

parallel  input/outpui  48 

parallel  work  transfer  467, 468, 469 

paruybil  39,40 

parity  generation  524 

parity/overflow  (P/V>  !75 

PC  52 

PIC  446.506 
PIO  48,511.512,513,514,515,518 

pointers  5 1 ,  62, 444,  539,  544,  550, 55 1 
polling  466,469,492,521,544 

polling  loop  493,494 

POPqq  373 

POP  iX  375 

POP  lY  377 

pop  53,  76,  154 

port  511,515,516 

positional  notation  20 

positive  24,  26,  32 

posi-indexmg  442, 443 

power  failures  48 

pre-indexing  442 

printer  44,  479,  495 

program  16,48 

program  counter  52 

program  development  579,  584 

program  loops  63,121 
programmable input/outputchip  51! 
programmable  interval 

timer  (PIT)  463,465 

programmer's  model  94 

programming      15,  !6,  515,  518, 602 

programmmg  language  16 

pseudo-instructions  98 


pulse  462, 467 

puise  counting  466 

punch  495 

PUSH  qq  379 

PUSH  !X  381 

PUSH  lY  383 

push  53,76,154 


Q 

queue 

R 

R 

RAM  48,75, 

random  element 

RLCA 

RD 

read  operation 
read-only  memory 
read-write  memory 
recursion 
reference  table 
register  addressing 
register  indirect  addressing 
register-interrupt 
register  pairs 

registers  31,  5i,  149, 

relative  addressing 
relative  jump 
relays 

request  blocks 
RES  b.  s 
RESET 

restoring  method 
RET 
RETcc 
RETl 
RETN 
RETURN 
RFSH 
RLs 
RLA 
RLCr 
RLC{HU 
RLC(IX  +  d) 
RLC(!Y  +  d) 
RLD 
ROM 
rotation 


181 

181: 


543,  544 
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584,587 
541 
385 
92 
96,515 
48 
48.75 
148 
571 
438 
444, 448 
184 
51 

439,  474 

441,446 
156 

461,462 
543 
386 
92 
133 
389 
391 

393,501 


,395,499 
144,  !45 
93 
397 
399 
103 
402 
404 
406 
408 
48 

120,  155. 170,  171 
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rotate 

round  robm 

RRs 

RRA 

RRCs 

RRCA 

RRD 

RST 

RSTp 

riibout 


50, 156 
544,  545 
410 
412 
413 
415 
416 
183,500 
418 
467 


S  178 

saving  the  registers  502 

SBC  A,  s  420 

SBC  HL,  ss  422 

SCF  424 

scheduling  491 

searching  551,558,572 

segment  drivers  484 

segments  480,54! 

sensmg  pulses  466 

sequential  lists  540 

sequential  searching  546 

service  routing  492 

SET  b,  s  425 
seven-segment  iight-emittmg 

diode  (LEDl  480.481 

shift                50. 118,  120,  155,  156 

short  addressing  44 1 , 446, 449 

short  instruction  19 

sign  !78 

signal  461 

signed  binary  24,  25 

signed  numbers  532 

simple  list  55! 

simulator  583 

simultaneous  interrupts  507 

single-board  tnicrocomputers  587 

16-bit  accumulator  !03 

16  by  8  division  134,135 

16  by  16  multiplication  130.131 

skew  operations  !69 

skip  157 

SLA  s  428 

software  aids  582,  587 

SP  53 

special  digit  instructions  172 

speed  476 


SRAs 
SRLs 

stack  53,146,149,496. 

stack  pointer 

standard  architecture 

standard  P 10 

status  3 ! 

status  bits 

status  register 

storing  operands 

string  of  characters 

SUBA,  s 

subroutine  call 

subroutine  library 

subroutine  mechanism 

subroutine  parameters 

subrouimes  !42, 

subtraction 

subtract  (N) 

sum  of  N  elements 

symbolic 

symbols 

synchronous 

syntactic  ambiguity 

syntax 

system  architecture 


430 
432 

508,  539, 544 
53,  540 
49 
511 

,85,476,515 
50,512 
SO 
!02 
490 
434 
143.  146 
150 
144 
149 

147,443,598 
104 
175 
527, 528 
41,44 
592.  593 
471,496 
16 
544 
46 


T 

tables  526,539,540,551 

technological  development 

teletype  466,  485,  487 

temporary  register 

test  16 

testing  a  character 

timer 

time-sharing  system 

timing 

trace 

transfers 

trees 

truncaimg 
truth  table 

two's  compiemeni  25, 
two-level  directory 

U 

UART 
underflow 
utility  routmes 


,  554, 592 
602 
488,  489 
6i 

, 156, 172 
523 
465 
588 
463 
585 
52 

544,  545 
34 
167 

26,  27,  29 
541 


477,518 
32 
583 
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V 

V  28,  30,  31 

S  137 

vecioring  of  inierrup!s  504 

W 

W  87 

WAIT  92 

working  regisiers  <i^6 

WR  92 


X 

XOR  166,  !69 

XOR  s  436 

Z 

Z  87,  177 

Z80  registers  95 

zero  177 

zero  page  address  i  n  g  44 1 ,  446 

ZiiogZSOPlO  516.517 

ZilogZSOSlO  518 
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BASIC  PROGRAMS  FOR  SCIENTISTS  AND  ENGINEERS 

by  Alan  R.  Miller  340  pp.,  120  illustr.,  Ref.  B240 

This  second  book  in  the  "  Programs  for  Scientists  and  Engineers' '  series  provides  a 
library  of  problem  solvmg  programs  while  developing  proficiency  In  BASIC. 

INSIDE  BASIC  GAMES 

by  Richard  Mateosian   350  pp.,  240  Illustr.,  Ref.  B24S 

Teaches  interactive  BASIC  programming  through  games.  Games  are  written  in 
Microsoft  BASIC  and  can  run  on  the  TRS-80,  APPLE  II  and  PET/CBM. 

FIFTY  BASIC  EXERCISES 

by  J.P.  Laraoitier  240  pp.,  195  Illustr.,  Ref.  B250 

Teaches  BASIC  by  actual  practice  using  graduated  exercises  drawn  from  everyday 
applications.  All  programs  wntten  in  Microsoft  BASIC, 

EXECUTIVE  PLANNING  WITH  BASIC 

by  X.T.  Bui    I9Z  pp.,  19  illustr.,  Ref.  B380 

An  important  collection  of  business  management  decision  models  in  BASIC, 
including  Inventory  Management  (EOQ),  Critical  Path  Analysis  and  PERT, 
Financial  Ratio  Analysis,  Portfolio  Management,  and  much  more. 

BASIC  FOR  BUSINESS 

by  Douglas  Hergert  250  pp.,  15  illustr.,  Ref.  B390 

A  logically  organized,  no-nonsense  introduction  to  BASIC  programming  for 
business  applications.  Includes  many  fully  explained  accounting  programs,  and 
shows  you  how  to  wnte  them. 

YOUR  FIRST  COMPUTER 

by  Rodnay  Zaks  260  pp.,  150  illustr.,  Ref.  C200A 

The  most  popular  introduction  to  small  computers  and  their  peripherals:  what 
they  do  and  how  to  buy  one. 

DON'T  (of  How  to  Care  for  Your  Computer) 

by  Rodnay  Zaks  220  pp.,  100  Illustr.,  Ref.  C400 

The  correct  way  to  handle  and  care  for  ail  elements  of  a  computer  system  including 
what  to  do  when  something  doesn't  work. 

INTRODUCTION  TO  WORD  PROCESSING 
by  Hal  Glatzer  200  pp..  70  illustr.,  Ref.  WIOl 

Explains  in  plain  language  what  a  word  processor  can  do,  how  it  improves  produc- 
tivity, how  to  use  a  word  processor  and  how  to  buy  one  wisely. 

INTRODUCTION  TO  WORDSTAR 

by  Arthur  Naiman  200  pp.,  30  illustr,.  Ref.  WHO 

Makes  it  easy  to  learn  how  to  use  WordStar,  a  powerful  word  processing  program 
for  personal  computers. 

FROM  CHIPS  TO  SYSTEMS:  AN  INTRODUCTION  TO 
MICROPROCESSORS 

by  Rodnay  Zaks  560  pp.,  255  illustr.,  Ref.  C207A 

A  simple  and  comprehensive  introduction  to  microprocessors  from  both  a  hard- 
ware and  software  standpoint:  what  they  are,  how  they  operate,  how  to  assemble 
them  into  a  complete  system. 


MICROPROCESSOR  INTERFACING  TECHNIQUES 

by  Rodnay  Zaks  and  Austin  Lesea  460  pp.,  400  Illustr.,  Ref.  C207 
Complete  hardware  and  software  interconnect  techniques  including  D  to  A  con- 
version, peripherals,  standard  buses  and  troubleshooting. 

PROGRAMMING  THE  6502 

by  Rodnay  Zaks  390  pp.,  160  illustr.,  Ref.  C202 

Assembly  language  programming  for  the  6502,  from  basic  concepts  to  advanced 
data  structures, 

6502  APPLICATIONS  BOOK 

by  Radnay  Zaks   280  pp.,  205  Illustr.,  Ref.  D302 

Real  life  application  techniques:  the  mputioutput  book  for  the  6502. 

6502  GAMES 

by  Rodnay  Zaks  300  pp.,  140  Illustr.,  Ref.  G402 

Third  in  the  6502  series.  Teaches  more  advanced  programming  techniques,  using 
games  as  a  framework  for  learning. 

PROGRAMMING  THE  Z80 

by  Rodnay  Zaks   620  pp.,  200  lUuslr.,  Ref.  C280 

A  complete  course  in  programming  the  Z80  microprocessor  and  a  thorough  intro- 
duction to  assembly  language. 

PROGRAMMING  THE  Z8000 

by  Richard  Mateosian  300  pp.,  125  Illustr.,  Ref.  C28! 

How  to  program  the  Z8000  16-bit  microprocessor.  Includes  a  description  of  the 
architecture  and  function  of  the  Z8(XX)  and  its  family  of  support  chips. 

THE  CP/M  HANDBOOK  (with  MP/M) 

by  Rodnay  Zaks  330  pp.,  100  Illustr.,  Ref,  C300 

An  indispensable  reference  and  guide  to  CP/M — the  most  widely  used  operating 
system  for  small  computers. 

INTRODUCTION  TO  PASCAL  (Including  UCSD  PASCAL) 
by  Rodnay  Zaks  420  pp.,  130  Illustr.,  Ref.  P310 

A  step-by-step  introduction  for  anyone  wanting  to  learn  the  Pascal  language. 
Describes  UCSD  and  Standard  Pascals.  No  technical  background  is  assumed. 

THE  PASCAL  HANDBOOK 

by  Jacques  Tiberghlen  490  pp.,  350  IlIusEr.,  Ref.  P320 

A  dictionary  of  the  Pascal  language,  defining  every  reserved  word,  operator,  pro- 
cedure and  function  found  in  all  major  versions  of  Pascal. 

PASCAL  PROGRAMS  FOR  SCIENTISTS  AND  ENGINEERS 
by  Alan  Miller  400  pp.,  80  Illustr.,  Ref.  P340 

A  comprehensive  collection  of  frequently  used  algorithms  for  scientific  and 
technical  applications,  programmed  in  Pascal,  includes  such  programs  as  curve- 
fitting,  integrals  and  statistical  techniques, 

APPLE  PASCAL  GAMES 

by  Douglas  Hergerl  and  Joseph  T.  Kalash   380  pp.,  40  illustr.,  Ref.  P360 

A  collection  of  the  most  popular  computer  games  in  Pascal  challenging  the  reader 

not  only  to  play  but  to  investigate  how  games  are  implemented  on  the  computer. 


INTRODUCTION  TO  UCSD  PASCAL  SYSTEMS 

by  Charles  T.  Grant  and  Jon  Butah   300  pp., !  10  iUusir.,  Ref.  P370 

A  simple,  clear  introduction  to  the  UCSD  Pascal  Operating  System  for  beginners 

through  experienced  programmers. 

INTERNATIONAL  MICROCOMPUTER  DICTIONARY 

im  pp.,  Ref,  X2 

Ail  the  definitions  and  acronyms  of  microcomputer  jargon  defined  m  a  handy 
pocket-size  edition.  Includes  translations  of  the  most  popular  terms  into  ten 
languages. 

MICROPROGRAMMED  APL  IMPLEMENTATION 

by  Rodnay  Zaks   350  pp..  Ref.  ZIO 

An  expert-level  text  presenting  the  complete  conceptual  analysis  and  design  of  an 
APL  interpreter,  and  actual  listings  of  the  microcode. 


SELF  STUD  Y  COURSES 


Recorded  live  at  seminars  given  by  recognized  professionals  m  the  microprocessor 
field. 

INTRODUCTOR  Y  SHOR  T  COURSES: 

Each  includes  two  cassettes  plus  special  coordinated  workbook.  (2Vi  hours} 

SIO—INTRODUCTION  TO  PERSONAL  AND  BUSINESS 
COMPUTING 

A  comprehensive  introduction  to  small  computer  systems  for  those  planning  to 
use  or  buy  one,  including  peripherals  and  pitfalls. 

51—  INTRODUCTION  TO  MICROPROCESSORS 

How  microprocessors  work,  including  basic  concepts,  applications,  advantages 
and  disadvantages. 

52—  PROGRAMMING  MICROPROCESSORS 

The  companion  to  SI .  How  to  program  any  standard  microprocessor,  and  how  it 
operates  mternaliy.  Requires  a  basic  understanding  of  microprocessors. 

S3~DESIGNING  A  MICROPROCESSOR  SYSTEM 

Learn  how  to  interconnect  a  complete  system,  wire  by  wire.  Techniques  discussed 
are  applicable  to  all  standard  microprocessors. 

INTRODUCTOR  Y  COMPREHENSIVE  COURSES: 

Each  includes  a  300-500  page  seminar  book  and  seven  or  eight  C90  cassettes. 

SB3— MICROPROCESSORS 

This  seminar  teaches  all  aspects  of  microprocessors:  from  the  operation  of  an  MPU 
to  the  complete  interconnect  of  a  system.  The  basic  hardware  course.  (12  hours) 

SB2~-MICROPROCESSOR  PROGRAMMING 

The  basic  software  course:  step  by  step  through  all  the  important  aspects  of  micro- 
computer programming.  (10  hours) 


ADVANCED  COURSES: 

Each  includes  a  300-500  page  workbook  and  three  or  four  C90  cassettes. 
SB3— SEVERE  ENVIRONMENT/MILITARY 
MICROPROCESSOR  SYSTEMS 

Complete  discussion  of  constraints,  techniques  and  systenis  for  severe  environ- 
mental applications,  including  Hughes,  Raytheon,  Actron  and  other  militarized 
systems.  (6  hours) 

SB5— BIT-SLICE 

Learn  how  to  build  a  complete  system  with  bit  slices.  Also  examines  mnovative 
applications  of  bit  slice  techniques.  (6  hours) 

SB6— INDUSTRIAL  MICROPROCESSOR  SYSTEMS 

Seminar  examines  actual  industnai  hardware  and  software  techniques,  components, 
programs  and  cost,  {4Yi  hours) 

SB7— MICROPROCESSOR  INTERFACING 

Explains  how  to  assemble,  interface  and  interconnect  a  system.  (6  hours). 


FOR  A  COMPLETE  CATALOG 
OF  OUR  PUBLICATIONS 


U.S.A 
2344  Sixth  Street 
Berkeley, 
California  94710 
Tel:  (415)  848-8233 
Telex:  336311 


SYBEX-EUROPE 
4  Place  Felix  Eboue 
75583  Paris  Cedex  12 
Tel:  1/347-30-20 
Teiex:  211801 


SYBEX-VERLAG 
Heyestr.  22 
4000  Dusseldorf  12 
West  Germany 
Tel:  (0211)  287066 
Teiex:  08  588  163 


^YBEX 


PROGRAMMING  THE  380 


has  besn  designed  both  as  educational  lea  and  as  a  self-contained  relerence  book  As  ?ur.v,  -t 
can  be  u=  ;d  as  a  cornpl''-:e  introductory  book  on  programming  ranging  Irom  th*-  basic  concepts  to 
adv'ttftcec  data  structt^res  manipulations. 

It  also  coniaiP'i  a  comprehensive  description  of  all  the  Z80  instructions  as  well  as  its  ifit°>r»a( 
operation,  and  sf'ould  provide  a  comprehensive  refetence  for  the  reader  who  is  already  farrilia' 
with  the  prircipies  of  prog  ramming,  but  wishes  to  learn  Hie  Z80- 

This  book  is  the  result  of  extensive  experience  by  the  author  in  the  field  oi  edrjaiton  and 
programming.  As  such,  it  has  been  designed  to  be  clear  and  easy  lo  read.  All  concapts  are 
exp'dined  in  simple  yet  precise  terms,  building  progtessively  towards  more  complex  teohniquss 
T:,e  reader  wiW  gain  not  only  an  understanding  of  prfigramming  in  the  langu£ge  of  th^  Z80  "ut  also 
a  detailed  understanding  of  the  way  a  microprocessor  such  as  the  Z80  actually  exe^  Jtes 
instruclii-'ni.  The  reader  will  iollow  the  flow  of  execution  between  the  various  registers  and  slontj 
the  buses  This  is  indispensible  for  effective  programming  at  machine  level  in  the  world  of 
microprocessors  Because  pr.jgranj.ning  is  not  just  the  skill  of  coding     algonthm  into  a 
progr£mming  language  but  also  the  art  of  designing  appropriate  data  jlruciuret.  an  t<tensive 
chapter  on  data  structures  is  presenter  which  both  introduces  the  concepts  and  acti  il  application 
programs.  The  reader  will  fina  there  lists,  taoles.  b:r>ary  trees,  and  the  required  algorit  ims 

After  reading  this  book.  tKe  reader  shouia  havf>  acquired  all  the  basic  skills  requn' d  lo 
program  not  just  at  the  elementary  level,  but  in  mo^i  praclical  cases. 
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Dr.  Rodnay  Zaks  has  been  involved  with  the  industrial  use  of  microprocessors  since  thay  first 
appeared.  He  is  the  author  of  a  number  of  best-selling  books  on  all  aspects  of  microproc.>;  sors. 
He  has  taught  microprocessor  courses  to  more  than  5,000  people  internationally,  rangino  Tom  the 
inifocuctory  level  to  bit-slice  niicfoprogramming  techniques  He  holds  a  Ph.D.  :n  Compute^ 
Scerxe  Irom  the  University  of  California  al  Berkeley,  and  is  a  member  of  ACM  ?nd  lEEF 
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